:root {
  --ink: #25332f;
  --muted: #74807b;
  --paper: #f8f7f3;
  --white: #fff;
  --line: #e7e6df;
  --green: #244a40;
  --green-soft: #eaf0ed;
  --coral: #d96d5b;
  --coral-soft: #fbefeb;
  --shadow: 0 16px 46px rgba(31, 53, 46, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Noto Sans CJK SC", sans-serif; -webkit-font-smoothing: antialiased; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 342px 1fr; }
.sidebar { position: sticky; top: 0; height: 100vh; padding: 36px 40px; color: white; background: var(--green); display: flex; flex-direction: column; overflow: hidden; }
.sidebar::before, .sidebar::after { content: ""; position: absolute; border: 1px solid rgba(255,255,255,.09); border-radius: 50%; pointer-events: none; }
.sidebar::before { width: 320px; height: 320px; top: -180px; right: -190px; }
.sidebar::after { width: 240px; height: 240px; bottom: -150px; left: -100px; }
.brand { color: white; text-decoration: none; display: flex; align-items: center; gap: 12px; position: relative; z-index: 1; }
.brand-mark { width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.6); display: grid; place-items: center; border-radius: 12px 12px 12px 3px; font-family: "Noto Serif SC", serif; font-size: 23px; }
.brand strong, .brand small { display: block; }
.brand strong { font-family: "Noto Serif SC", serif; font-size: 22px; letter-spacing: .16em; }
.brand small { margin-top: 1px; color: rgba(255,255,255,.58); font-size: 10px; letter-spacing: .08em; }
.sidebar-intro { margin: 64px 0 45px; position: relative; z-index: 1; }
.eyebrow { margin: 0 0 12px; font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.6); }
.eyebrow.coral { color: var(--coral); }
.sidebar-intro h1 { margin: 0; font-family: "Noto Serif SC", serif; font-size: 31px; line-height: 1.42; font-weight: 600; letter-spacing: .03em; }
.sidebar-intro > p:last-child { margin: 18px 0 0; color: rgba(255,255,255,.62); font-size: 13px; line-height: 1.8; }
.steps { display: grid; gap: 7px; position: relative; z-index: 1; }
.step { width: 100%; border: 0; border-radius: 12px; padding: 13px; background: transparent; color: rgba(255,255,255,.45); display: grid; grid-template-columns: 33px 1fr; gap: 10px; text-align: left; cursor: pointer; transition: .2s ease; }
.step:hover, .step.active { background: rgba(255,255,255,.09); color: white; }
.step > span:first-child { font-family: serif; font-size: 12px; padding-top: 3px; color: #df927f; }
.step strong, .step small { display: block; }
.step strong { font-size: 13px; font-weight: 600; }
.step small { margin-top: 3px; font-size: 10px; color: inherit; opacity: .65; }
.trust-note { margin-top: auto; position: relative; z-index: 1; color: rgba(255,255,255,.48); font-size: 10px; }
.trust-note span { display: inline-grid; place-items: center; width: 17px; height: 17px; margin-right: 7px; border: 1px solid rgba(255,255,255,.25); border-radius: 50%; }

.main-panel { min-width: 0; }
.topbar { height: 76px; padding: 0 7vw; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; background: rgba(248,247,243,.92); backdrop-filter: blur(14px); position: sticky; top: 0; z-index: 10; }
.mobile-brand { display: none; }
.draft-status { color: var(--muted); font-size: 12px; }
.draft-status i { display: inline-block; width: 6px; height: 6px; margin-right: 7px; border-radius: 50%; background: #79a493; }
.text-button { border: 0; border-bottom: 1px solid #b9bdb8; padding: 4px 1px; background: none; font-size: 12px; cursor: pointer; }
.form-view, .result-view { max-width: 930px; margin: 0 auto; padding: 72px 42px 100px; }
.form-heading { margin-bottom: 40px; }
.form-heading h2, .result-hero h2 { margin: 0; font-family: "Noto Serif SC", serif; font-weight: 600; font-size: clamp(28px, 3vw, 39px); letter-spacing: .01em; }
.form-heading > p:last-child { color: var(--muted); margin: 13px 0 0; font-size: 14px; }
form { display: grid; gap: 20px; }
.form-card, .result-card { background: rgba(255,255,255,.85); border: 1px solid var(--line); border-radius: 18px; box-shadow: 0 4px 24px rgba(37,51,47,.025); }
.form-card { padding: 31px 34px 34px; scroll-margin-top: 95px; }
.card-title { display: flex; align-items: center; gap: 14px; padding-bottom: 25px; margin-bottom: 26px; border-bottom: 1px solid var(--line); }
.card-title > span, .result-card-head > div > span { width: 31px; height: 31px; flex: 0 0 auto; display: grid; place-items: center; color: var(--coral); background: var(--coral-soft); border-radius: 50%; font-family: serif; font-size: 11px; }
.card-title h3, .card-title p { margin: 0; }
.card-title h3 { font-family: "Noto Serif SC", serif; font-size: 18px; }
.card-title p { margin-top: 3px; color: var(--muted); font-size: 11px; }
.field-grid { display: grid; gap: 18px; }
.field-grid.two { grid-template-columns: repeat(2, 1fr); }
.airport-grid { display: grid; grid-template-columns: minmax(150px, 1.3fr) minmax(90px, .7fr) 28px minmax(150px, 1.3fr) minmax(90px, .7fr); gap: 10px; align-items: end; }
.airport-arrow { height: 45px; display: grid; place-items: center; color: var(--coral); font-size: 17px; }
label, legend { font-size: 12px; font-weight: 600; }
input[type=date], select, textarea { width: 100%; margin-top: 9px; border: 1px solid #dfe1dc; border-radius: 9px; padding: 12px 13px; color: var(--ink); background: #fcfcfa; outline: none; transition: .2s ease; }
input[type=date], select { height: 45px; }
textarea { resize: vertical; line-height: 1.7; }
input:focus, select:focus, textarea:focus { border-color: #7b9c91; box-shadow: 0 0 0 3px rgba(69,112,97,.08); }
fieldset { margin: 25px 0; padding: 0; border: 0; }
legend { margin-bottom: 12px; }
legend small { margin-left: 7px; color: #a1a7a3; font-size: 10px; font-weight: 400; }
.choice-row { display: flex; flex-wrap: wrap; gap: 9px; }
.choice input { position: absolute; opacity: 0; pointer-events: none; }
.choice span { display: block; padding: 9px 14px; border: 1px solid #dfe1dc; border-radius: 99px; color: #5e6965; background: #fcfcfa; font-size: 11px; font-weight: 500; cursor: pointer; transition: .15s ease; }
.choice span:hover { border-color: #91a69f; }
.choice input:checked + span { color: var(--green); border-color: #6f9185; background: var(--green-soft); box-shadow: inset 0 0 0 1px rgba(36,74,64,.05); }
.route-planning-block { margin-top: 28px; padding-top: 27px; border-top: 1px solid var(--line); }
.subsection-heading, .must-visit-heading { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.subsection-heading { margin-bottom: 20px; }
.subsection-heading strong, .subsection-heading small, .must-visit-heading strong, .must-visit-heading small { display: block; }
.subsection-heading strong, .must-visit-heading strong { font-family: "Noto Serif SC", serif; font-size: 14px; }
.subsection-heading small, .must-visit-heading small { margin-top: 4px; color: var(--muted); font-size: 9px; font-weight: 400; }
.subsection-heading > span { flex: 0 0 auto; padding: 5px 9px; color: var(--coral); background: var(--coral-soft); border-radius: 99px; font-size: 9px; }
.field-hint { display: block; margin: 7px 0 0; color: var(--muted); font-size: 9px; font-weight: 400; }
.must-visit-heading { margin: 26px 0 12px; }
.add-place-button { flex: 0 0 auto; border: 1px solid #b9ccc5; border-radius: 8px; padding: 7px 11px; color: var(--green); background: var(--green-soft); font-size: 10px; font-weight: 600; cursor: pointer; }
.add-place-button span { font-size: 13px; margin-right: 3px; }
.must-visit-list { display: grid; gap: 9px; }
.must-visit-row { display: grid; grid-template-columns: minmax(170px, 1.5fr) minmax(100px, .7fr) minmax(105px, .8fr) 30px; gap: 9px; align-items: end; padding: 13px; border: 1px solid #e3e5e1; border-radius: 11px; background: #fafaf7; }
.must-visit-row label { font-size: 9px; color: var(--muted); }
.must-visit-row input, .must-visit-row select { height: 38px; margin-top: 6px; padding: 8px 10px; font-size: 10px; }
.remove-place-button { width: 30px; height: 38px; border: 0; border-radius: 7px; color: #a78e87; background: transparent; font-size: 17px; cursor: pointer; }
.remove-place-button:hover { color: var(--coral); background: var(--coral-soft); }
.submit-area { margin-top: 8px; padding: 24px 2px; display: flex; justify-content: space-between; align-items: center; }
.submit-area strong, .submit-area span { display: block; }
.submit-area strong { font-size: 12px; }
.submit-area > div > span { margin-top: 3px; color: var(--muted); font-size: 10px; }
.primary-button { min-width: 248px; border: 0; border-radius: 10px; padding: 5px 6px 5px 21px; display: flex; align-items: center; justify-content: space-between; color: white; background: var(--green); cursor: pointer; box-shadow: 0 10px 24px rgba(36,74,64,.18); transition: transform .2s ease, box-shadow .2s ease; }
.primary-button:hover { transform: translateY(-2px); box-shadow: 0 14px 27px rgba(36,74,64,.23); }
.primary-button span { font-size: 12px; font-weight: 600; }
.primary-button b { width: 38px; height: 38px; display: grid; place-items: center; color: var(--green); background: white; border-radius: 8px; font-size: 17px; }
footer { padding: 28px 25px; text-align: center; color: #9aa09d; border-top: 1px solid var(--line); }
footer strong { font-family: "Noto Serif SC", serif; font-size: 10px; letter-spacing: .15em; }
footer p { max-width: 720px; margin: 9px auto 0; font-size: 8px; line-height: 1.7; letter-spacing: 0; }

.result-view { max-width: 1040px; }
.result-top { display: flex; justify-content: space-between; margin-bottom: 38px; }
.back-button, .outline-button, .copy-button { border: 0; background: none; cursor: pointer; font-size: 11px; }
.back-button { color: var(--muted); padding: 8px 0; }
.outline-button, .copy-button { padding: 9px 14px; border: 1px solid #d8ddd9; border-radius: 8px; background: white; }
.result-hero { text-align: center; padding: 18px 0 35px; }
.result-hero > p:nth-of-type(2) { max-width: 610px; margin: 14px auto 20px; color: var(--muted); line-height: 1.8; font-size: 13px; }
.summary-tags { display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.summary-tags span { padding: 6px 11px; border-radius: 99px; background: var(--green-soft); color: var(--green); font-size: 10px; }
.notice { display: flex; gap: 12px; padding: 15px 18px; margin: 0 0 18px; border: 1px solid #eadfd2; border-radius: 12px; background: #fdf8f2; color: #796b5e; }
.notice > span { width: 20px; height: 20px; display: grid; place-items: center; border: 1px solid #cfaa84; border-radius: 50%; font-family: serif; font-size: 11px; }
.notice p { margin: 0; font-size: 10px; line-height: 1.7; }
.notice strong { display: block; color: #5f5145; font-size: 11px; }
.consult-intro { margin: 0 0 18px; padding: 27px 30px; border-radius: 16px; color: white; background: var(--green); display: flex; align-items: center; justify-content: space-between; gap: 25px; box-shadow: 0 14px 35px rgba(36,74,64,.16); }
.consult-intro h3, .consult-intro p { margin: 0; }
.consult-intro h3 { font-family: "Noto Serif SC", serif; font-size: 21px; }
.consult-intro > div > p:last-child { margin-top: 7px; color: rgba(255,255,255,.65); font-size: 10px; }
.consult-primary { flex: 0 0 auto; border: 0; border-radius: 9px; padding: 12px 15px; color: var(--green); background: white; font-size: 10px; font-weight: 600; cursor: pointer; }
.consult-primary span { margin-left: 8px; }
.pricing-section { margin: 18px 0; padding: 30px; border: 1px solid var(--line); border-radius: 18px; background: rgba(255,255,255,.85); }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 24px; margin-bottom: 22px; }
.section-heading h3, .section-heading p { margin: 0; }
.section-heading h3 { font-family: "Noto Serif SC", serif; font-size: 20px; }
.section-heading > p { max-width: 290px; color: var(--muted); font-size: 9px; line-height: 1.7; text-align: right; }
.plan-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 11px; }
.plan-card { position: relative; min-height: 225px; padding: 20px; border: 1px solid var(--line); border-radius: 13px; background: #fff; display: flex; flex-direction: column; }
.plan-card.featured-plan { border-color: #7f9e93; box-shadow: 0 9px 23px rgba(36,74,64,.08); }
.plan-label { color: var(--coral); font-size: 8px; font-weight: 700; letter-spacing: .08em; }
.plan-card h4 { margin: 8px 0 13px; font-family: "Noto Serif SC", serif; font-size: 14px; }
.plan-price strong { font-family: "Noto Serif SC", serif; font-size: 23px; }
.plan-price small { color: var(--muted); font-size: 9px; }
.plan-card > p { margin: 12px 0 17px; color: var(--muted); font-size: 9px; line-height: 1.65; }
.plan-features { margin: 12px 0 14px; padding: 0; list-style: none; display: grid; gap: 7px; }
.plan-features li { position: relative; padding-left: 16px; color: #56645f; font-size: 9px; line-height: 1.55; }
.plan-features li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--coral); font-weight: 700; }
.plan-card .service-boundary { margin: 0 0 16px; padding: 9px 10px; border-radius: 7px; color: #82756b; background: #fdf8f2; font-size: 8px; line-height: 1.6; }
.plan-card button, .service-item button { width: 100%; margin-top: auto; padding: 9px; border: 1px solid #c7d4cf; border-radius: 7px; color: var(--green); background: var(--green-soft); font-size: 9px; font-weight: 600; cursor: pointer; }
.current-tag { margin-top: auto; padding: 8px; border-radius: 7px; color: var(--muted); background: #f2f2ee; text-align: center; font-size: 9px; }
.service-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 9px; }
.service-item { padding: 17px 14px; border: 1px solid var(--line); border-radius: 12px; background: white; display: flex; flex-direction: column; }
.service-icon { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 10px; color: var(--coral); background: var(--coral-soft); font-size: 9px; font-weight: 700; }
.service-item h4 { margin: 12px 0 7px; font-family: "Noto Serif SC", serif; font-size: 13px; }
.service-item > strong { font-size: 12px; }
.service-item > strong small { color: var(--muted); font-size: 8px; font-weight: 400; }
.service-item > p { margin: 5px 0 15px; color: var(--muted); font-size: 8px; }
.service-terms { margin-top: 13px; padding: 13px 15px; border-radius: 9px; display: flex; gap: 12px; color: #796b5e; background: #fdf8f2; }
.service-terms span { flex: 0 0 auto; color: var(--coral); font-size: 9px; font-weight: 700; }
.service-terms p { margin: 0; font-size: 9px; line-height: 1.7; }
.contact-panel { margin-top: 13px; padding: 18px 19px; border-radius: 11px; color: white; background: var(--green); display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.contact-panel span, .contact-panel strong, .contact-panel small { display: block; }
.contact-panel span { color: rgba(255,255,255,.6); font-size: 8px; }
.contact-panel strong { margin-top: 4px; font-size: 17px; letter-spacing: .05em; }
.contact-panel small { margin-top: 4px; color: rgba(255,255,255,.55); font-size: 8px; }
.contact-panel button { flex: 0 0 auto; border: 0; border-radius: 8px; padding: 10px 14px; color: var(--green); background: white; font-size: 9px; font-weight: 700; cursor: pointer; }
.result-card { padding: 28px 30px; margin-bottom: 18px; }
.result-card-head { min-height: 38px; display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; }
.result-card-head > div { display: flex; align-items: center; gap: 12px; }
.result-card-head h3 { margin: 0; font-family: "Noto Serif SC", serif; font-size: 18px; }
.result-card-head small { color: var(--muted); font-size: 10px; }
.itinerary { border-left: 1px solid #dce3df; margin-left: 13px; }
.day-item { position: relative; display: grid; grid-template-columns: 105px 1fr; gap: 15px; padding: 0 0 28px 23px; }
.day-item:last-child { padding-bottom: 0; }
.day-item::before { content: ""; position: absolute; left: -5px; top: 5px; width: 9px; height: 9px; border: 2px solid white; border-radius: 50%; background: var(--coral); box-shadow: 0 0 0 1px var(--coral); }
.day-label strong, .day-label span { display: block; }
.day-label strong { font-family: "Noto Serif SC", serif; font-size: 13px; }
.day-label span { margin-top: 4px; color: var(--muted); font-size: 9px; }
.day-content h4 { margin: 0 0 7px; font-size: 13px; }
.day-content p { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.75; }
.day-content .route { color: var(--green); }
.maps-link { display: inline-flex; align-items: center; gap: 5px; margin-top: 8px; padding: 6px 9px; border: 1px solid #cad8d3; border-radius: 7px; color: var(--green); background: var(--green-soft); text-decoration: none; font-size: 9px; font-weight: 600; }
.maps-link:hover { border-color: #7f9e93; }
.result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.budget-row { padding: 10px 0; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px dashed var(--line); font-size: 11px; }
.budget-row > div strong, .budget-row > div small { display: block; }
.budget-row > div small { margin-top: 3px; color: var(--muted); font-size: 8px; font-weight: 400; }
.budget-row.transport-row { padding: 12px 0; }
.budget-row.transport-row > div strong { color: var(--green); }
.budget-row:last-child { border-bottom: 0; }
.budget-row span { color: var(--muted); }
.budget-row strong { font-size: 12px; }
.budget-row.total { margin-top: 8px; padding-top: 16px; border-top: 1px solid var(--ink); border-bottom: 0; }
.budget-overview { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; margin: -5px 0 14px; }
.budget-stat { padding: 13px 14px; border-radius: 9px; background: var(--green-soft); }
.budget-stat span, .budget-stat strong { display: block; }
.budget-stat span { color: var(--muted); font-size: 8px; }
.budget-stat strong { margin-top: 4px; color: var(--green); font-family: "Noto Serif SC", serif; font-size: 15px; }
.budget-note { margin: 13px 0 0; padding-top: 12px; border-top: 1px solid var(--line); color: var(--muted); font-size: 8px; line-height: 1.7; }
.check-item { display: flex; gap: 10px; align-items: flex-start; padding: 10px 0; border-bottom: 1px dashed var(--line); }
.check-item:last-child { border: 0; }
.check-item i { width: 18px; height: 18px; flex: 0 0 auto; display: grid; place-items: center; border-radius: 5px; background: var(--green-soft); color: var(--green); font-style: normal; font-size: 10px; }
.check-item strong, .check-item small { display: block; }
.check-item strong { font-size: 11px; }
.check-item small { margin-top: 3px; color: var(--muted); font-size: 9px; }
.booking-copy-card { background: #f1f4f2; }
.copy-context { margin-bottom: 15px; display: flex; align-items: center; gap: 9px; font-size: 10px; }
.copy-context span { padding: 4px 7px; background: white; border-radius: 5px; color: var(--muted); }
.copy-context strong { font-size: 10px; }
pre { margin: 0; padding: 22px; border: 1px solid #dce3df; border-radius: 10px; background: white; white-space: pre-wrap; font-family: "Noto Sans SC", sans-serif; font-size: 11px; line-height: 1.9; }
.translation { margin: 12px 0 0; color: var(--muted); font-size: 10px; line-height: 1.7; }
.prep-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px 22px; }
.prep-item { display: flex; gap: 9px; align-items: center; padding: 9px 0; font-size: 11px; }
.prep-item span { width: 18px; height: 18px; display: grid; place-items: center; color: var(--coral); border: 1px solid #e7c8c0; border-radius: 50%; font-size: 9px; }
.toast { position: fixed; left: 50%; bottom: 30px; z-index: 50; transform: translate(-50%, 20px); padding: 10px 18px; border-radius: 8px; color: white; background: var(--ink); opacity: 0; pointer-events: none; font-size: 11px; transition: .25s ease; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.consult-modal[hidden] { display: none; }
.consult-modal { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 20px; }
.modal-backdrop { position: absolute; inset: 0; border: 0; background: rgba(21,37,32,.62); backdrop-filter: blur(4px); cursor: pointer; }
.modal-dialog { position: relative; width: min(500px, 100%); max-height: calc(100vh - 40px); overflow: auto; padding: 31px; border-radius: 18px; background: var(--paper); box-shadow: 0 25px 70px rgba(19,35,30,.28); }
.modal-dialog h3 { margin: 0; font-family: "Noto Serif SC", serif; font-size: 23px; }
.modal-lead { margin: 9px 0 22px; color: var(--muted); font-size: 10px; line-height: 1.7; }
.modal-dialog label { display: block; margin-top: 14px; }
.modal-close { position: absolute; right: 20px; top: 17px; border: 0; background: none; color: var(--muted); font-size: 22px; cursor: pointer; }
.modal-copy-button { width: 100%; margin-top: 17px; padding: 13px; border: 0; border-radius: 9px; color: white; background: var(--green); font-size: 11px; font-weight: 600; cursor: pointer; }
.modal-note { margin: 10px 0 0; color: var(--muted); text-align: center; font-size: 8px; }

@media (max-width: 900px) {
  .app-shell { display: block; }
  .sidebar { display: none; }
  .topbar { height: 63px; padding: 0 22px; }
  .mobile-brand { display: inline-block; margin-right: 14px; font-family: "Noto Serif SC", serif; font-size: 17px; font-weight: 700; }
  .form-view, .result-view { padding: 48px 22px 75px; }
  .service-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 620px) {
  .form-view, .result-view { padding-left: 16px; padding-right: 16px; }
  .form-heading { margin-bottom: 27px; }
  .form-heading h2 { font-size: 27px; line-height: 1.45; }
  .form-card, .result-card { padding: 24px 20px; border-radius: 14px; }
  .subsection-heading { align-items: flex-start; }
  .subsection-heading > span { display: none; }
  .must-visit-heading { align-items: flex-end; }
  .must-visit-row { grid-template-columns: 1fr 1fr; }
  .must-visit-row label:first-child { grid-column: 1 / -1; }
  .remove-place-button { grid-column: 1 / -1; width: 100%; height: 30px; border: 1px dashed #e4d6d1; }
  .field-grid.two, .result-grid, .prep-grid { grid-template-columns: 1fr; }
  .airport-grid { grid-template-columns: 1fr 1fr; }
  .airport-arrow { display: none; }
  .field-grid.two { gap: 23px; }
  .submit-area { align-items: stretch; flex-direction: column; gap: 17px; }
  .primary-button { min-width: 0; width: 100%; }
  .result-top { margin-bottom: 20px; }
  .day-item { grid-template-columns: 1fr; gap: 7px; }
  .result-card-head small { display: none; }
  .result-card { padding: 23px 19px; }
  .consult-intro, .section-heading { align-items: stretch; flex-direction: column; }
  .consult-primary { width: 100%; }
  .section-heading > p { text-align: left; }
  .pricing-section { padding: 23px 18px; }
  .plan-grid, .service-grid { grid-template-columns: 1fr; }
  .plan-card { min-height: 0; }
  .service-terms { flex-direction: column; gap: 6px; }
  .contact-panel { align-items: stretch; flex-direction: column; }
  .contact-panel button { width: 100%; }
  .modal-dialog { padding: 26px 20px; }
}

@media print {
  .sidebar, .topbar, .result-top, footer, .toast { display: none !important; }
  .app-shell { display: block; }
  .result-view { padding: 10px; max-width: none; }
  .result-card { break-inside: avoid; box-shadow: none; }
}
