/* ═══════════════════════════════════════
   sinnetroy.com — Complete Stylesheet
   Dr. Sinnet Roy · Plastic Surgeon Kochi
   ═══════════════════════════════════════ */

/* ── RESET & VARIABLES ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --dark:#0e1d15;--dark2:#162818;--sage:#8aab94;--teal:#3a6e52;--btn:#2d5c43;
  --cream:#f4efe5;--warm:#faf7f2;--ink:#1a2c20;--muted:#6b7c70;--border:#ddd8ce;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --pad:clamp(1.25rem,5vw,2.5rem)
}
html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
body{font-family:var(--sans);font-size:15px;line-height:1.7;color:var(--ink);background:var(--warm)}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;height:60px;background:rgba(14,29,21,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:0 max(var(--pad),env(safe-area-inset-left)) 0 max(var(--pad),env(safe-area-inset-right))}
.logo{font-family:var(--serif);font-size:1.1rem;color:#fff}
.logo em{font-style:italic;color:var(--sage)}
.nav-links{display:flex;align-items:center;gap:1rem}
.nav-links a{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.85);transition:color .2s}
.nav-links a:hover,.nav-links a[aria-current]{color:#fff}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:.45rem 1.2rem;font-family:var(--sans);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;background:var(--btn);color:#fff;border:none;cursor:pointer;transition:background .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.btn:hover{background:var(--teal)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.25);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.4)}
.wa-btn{display:inline-flex;align-items:center;gap:.6rem;min-height:44px;padding:.5rem 1.4rem;background:#1a6e3b;color:#fff;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;transition:background .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.wa-btn:hover{background:#145c31}
.wa-btn svg{flex-shrink:0}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;align-items:center}
.menu-btn{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;min-height:44px;min-width:44px;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}
.menu-btn span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,.8)}

/* ── SHARED LABELS ── */
.eyebrow{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);margin-bottom:1rem}
.section-tag{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.section-label{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}

/* ══════════════════════════════════
   INDEX PAGE — Hero, About, Ticker, Instagram
   ══════════════════════════════════ */

/* Hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:5rem var(--pad) 3rem}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(14,29,21,.7),rgba(14,29,21,.85));z-index:1}
.hero-text{position:relative;z-index:2;max-width:680px;text-align:center;margin:0 auto}
.hero-title{font-family:var(--serif);font-size:clamp(2.6rem,7vw,4.5rem);font-weight:400;color:#fff;line-height:1.05;margin-bottom:.75rem}
.hero-title em{font-style:italic;color:var(--sage)}
.hero-hosp{font-size:.82rem;color:rgba(255,255,255,.5);margin-bottom:1rem;line-height:1.7}
.hero-hosp em{font-style:italic;color:var(--sage)}
.hero-desc{font-size:.88rem;color:rgba(255,255,255,.42);max-width:520px;margin:0 auto 2rem;line-height:1.85}
.hero-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-stats{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}
.stat-n{font-family:var(--serif);font-size:1.8rem;color:#fff;line-height:1}
.stat-l{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:.2rem}

/* Ticker */
.ticker{background:var(--dark);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);overflow:hidden;padding:.65rem 0}
.ticker-inner{display:flex;gap:1.5rem;animation:ticker-scroll 30s linear infinite;width:max-content}
.ticker-inner span{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.25);white-space:nowrap}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* About */
.about{display:grid;grid-template-columns:1fr 1.6fr;gap:0;max-width:1100px;margin:0 auto;padding:4rem var(--pad)}
.about-img{display:flex;align-items:flex-start;justify-content:center}
.about-img img{max-width:320px;width:100%;opacity:.95}
.about-txt{padding-left:2.5rem}
.about-h{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:400;margin-bottom:1.25rem;line-height:1.1}
.about-h em{font-style:italic;color:var(--teal)}
.quals{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem}
.qual-badge{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .6rem;background:var(--cream);color:var(--muted);border:1px solid var(--border)}
.about-p{font-size:.88rem;color:#3a4c3f;line-height:1.85;margin-bottom:.75rem}
.about-p:last-of-type{margin-bottom:1.25rem}
.about-stats{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem}
.astat-n{font-family:var(--serif);font-size:1.5rem;color:var(--ink);line-height:1}
.astat-l{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}

/* Instagram Box */
.insta-box{border-top:1px solid var(--border);padding-top:1.5rem;margin-top:.5rem}
.insta-box-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.insta-handle{font-size:.75rem;color:var(--muted)}
.insta-handle span{font-weight:500;color:var(--ink)}
.insta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.insta-cell{display:block;aspect-ratio:1;overflow:hidden;background:var(--cream);position:relative}
.insta-cell img{width:100%;height:100%;object-fit:cover;transition:opacity .3s}
.insta-cell:hover img{opacity:.85}
.insta-cell-reel::after{content:'▶';position:absolute;top:.4rem;right:.5rem;font-size:.55rem;color:#fff;background:rgba(0,0,0,.4);padding:.1rem .3rem;border-radius:2px;pointer-events:none}

/* ══════════════════════════════════
   PROCEDURES PAGE — Cards Grid
   ══════════════════════════════════ */
.page-header-inner{display:flex;align-items:center;gap:2rem;max-width:900px}
.page-surgeon{flex-shrink:0}
.page-surgeon img{width:clamp(70px,10vw,110px);opacity:.85}
.page-eyebrow{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);margin-bottom:.75rem}
.page-title{font-family:var(--serif);font-size:clamp(2.5rem,6vw,4rem);font-weight:400;color:#fff;line-height:1.05;margin-bottom:.75rem}
.page-title em{font-style:italic;color:var(--sage)}
.page-desc{font-size:.88rem;color:rgba(255,255,255,.45);line-height:1.85;max-width:520px}
.page-tagline{font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.85;max-width:520px;margin-bottom:2rem}

.procedures{max-width:1000px;margin:0 auto;padding:0 var(--pad)}
.cat-section{padding:2.5rem 0;border-bottom:1px solid var(--border)}
.cat-section:last-child{border-bottom:none}
.cat-label{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:1.25rem}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}
.card{background:#fff;border:1px solid var(--border);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.card:hover{border-color:var(--teal);box-shadow:0 4px 20px rgba(58,110,82,.06)}
.card-img{position:relative;background:var(--cream);overflow:hidden}
.card-img img{width:100%;aspect-ratio:4/3;object-fit:cover}
.card-badge{position:absolute;top:.6rem;left:.6rem;display:inline-block;font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;padding:.15rem .5rem}
.card-body{padding:1rem 1.1rem}
.card-name{font-family:var(--serif);font-size:1.1rem;font-weight:400;margin-bottom:.4rem;color:var(--ink)}
.card-desc{font-size:.78rem;color:var(--muted);line-height:1.7;margin-bottom:.75rem}
.card-link{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);font-weight:500;transition:gap .2s}
.card-link:hover{color:var(--ink)}

/* "More Procedures" card */
.card-more{border:1px dashed var(--border);display:flex;align-items:center;gap:1.25rem;padding:1.25rem;background:var(--cream);transition:border-color .2s}
.card-more:hover{border-color:var(--teal)}
.card-more-img img{width:80px;opacity:.7}
.card-more-body{flex:1}
.card-more-title{font-family:var(--serif);font-size:1.1rem;font-weight:400;margin-bottom:.3rem}
.card-more-title em{font-style:italic;color:var(--teal)}
.card-more-desc{font-size:.75rem;color:var(--muted);line-height:1.6;margin-bottom:.5rem}
.card-more-link{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);font-weight:500}

/* Badge colors */
.badge-cosmetic{background:#fbe8e4;color:#8b3a2a}
.badge-body{background:#e8f0eb;color:#2a5c3a}
.badge-reconstructive{background:#e4eaf5;color:#2a3c6b}
.badge-animated{background:#f0ece4;color:#5c4a2a}

/* ══════════════════════════════════
   CONSULTATION PAGE — Contact & Form
   ══════════════════════════════════ */
.page-inner{padding-right:1rem}
.wa-icon{flex-shrink:0}
.consult-header{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.page-header-img{display:flex;align-items:center;justify-content:center;padding:2rem 0}
.page-header-img img{max-width:340px;width:100%;opacity:.92}

.in-person{max-width:800px;margin:0 auto;padding:3.5rem var(--pad)}
.in-person-h{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.5rem);font-weight:400;margin-bottom:2rem;line-height:1.15}
.in-person-h em{font-style:italic;color:var(--teal)}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.contact-block h3{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.contact-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.85rem}
.contact-icon{flex-shrink:0;color:var(--teal);margin-top:.15rem}
.contact-text{font-size:.88rem;color:#3a4c3f;line-height:1.7}
.contact-text a{color:var(--teal);transition:color .2s}
.contact-text a:hover{color:var(--ink)}
.maps-link{display:inline-block;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);margin-top:.5rem;transition:color .2s}
.maps-link:hover{color:var(--ink)}

/* Enquiry Form */
.form-section{max-width:560px;margin:0 auto;padding:3.5rem var(--pad);border-top:1px solid var(--border)}
.form-h{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:400;margin-bottom:.5rem;text-align:center}
.form-h em{font-style:italic;color:var(--teal)}
.form-sub{font-size:.85rem;color:var(--muted);text-align:center;margin-bottom:2rem;line-height:1.7}
.form-section form{display:flex;flex-direction:column;gap:1.25rem}
.form-section label{display:block;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}
.form-section input,.form-section select,.form-section textarea{width:100%;padding:.7rem .9rem;font-family:var(--sans);font-size:.88rem;color:var(--ink);background:#fff;border:1px solid var(--border);transition:border-color .2s;-webkit-appearance:none;appearance:none}
.form-section input:focus,.form-section select:focus,.form-section textarea:focus{outline:none;border-color:var(--teal)}
.form-section textarea{min-height:120px;resize:vertical}
.form-note{font-size:.72rem;color:var(--muted);text-align:center;line-height:1.6}
.submit-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;width:100%;padding:.6rem 1.5rem;font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;background:var(--btn);color:#fff;border:none;cursor:pointer;transition:background .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.submit-btn:hover{background:var(--teal)}

/* ══════════════════════════════════
   SIMPLE PROCEDURE PAGES (shared)
   ══════════════════════════════════ */
.page-header{background:var(--dark);padding:7rem var(--pad) 4rem}
.breadcrumb{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1.25rem}
.breadcrumb a{color:rgba(255,255,255,.35);transition:color .2s}
.breadcrumb a:hover{color:var(--sage)}
.breadcrumb span{color:rgba(255,255,255,.5)}
.header-inner{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;max-width:900px}
.header-img{width:200px;flex-shrink:0;opacity:.85}
.proc-badge{display:inline-block;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .75rem;margin-bottom:1.25rem}

/* Content sections */
.content-section{padding:3.5rem var(--pad);max-width:800px;margin:0 auto}
.section-heading{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:400;margin-bottom:1.25rem;line-height:1.2}
.section-heading em{font-style:italic;color:var(--teal)}
.prose p{font-size:.92rem;color:#3a4c3f;line-height:1.85;margin-bottom:1rem}
.prose p:last-child{margin-bottom:0}
.candidates-list{list-style:none;padding:0;margin:0}
.candidates-list li{font-size:.88rem;color:#3a4c3f;line-height:1.75;padding:.5rem 0 .5rem 1.5rem;border-bottom:1px solid var(--border);position:relative}
.candidates-list li:last-child{border-bottom:none}
.candidates-list li::before{content:'→';position:absolute;left:0;color:var(--teal);font-size:.85rem}
.two-col-inner{max-width:800px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;padding:3.5rem var(--pad)}
.col-heading{font-family:var(--serif);font-size:1.4rem;font-weight:400;margin-bottom:.75rem}
.col-heading em{font-style:italic;color:var(--teal)}
.col-text{font-size:.88rem;color:#4a5c50;line-height:1.85}

/* ══════════════════════════════════
   ADVANCED PROCEDURE PAGES
   (rhinoplasty, abdominoplasty style)
   ══════════════════════════════════ */

/* Procedure hero (reusable for any advanced page) */
.proc-hero{background:var(--dark);padding:6.5rem var(--pad) 3rem;padding-left:max(var(--pad),env(safe-area-inset-left));padding-right:max(var(--pad),env(safe-area-inset-right))}
.proc-hero .breadcrumb{margin-bottom:1rem}
.proc-hero-inner{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;max-width:1000px}
.proc-hero .badge{display:inline-block;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;padding:.2rem .65rem;margin-bottom:.9rem}
.proc-hero h1{font-family:var(--serif);font-size:clamp(2.8rem,7vw,4.2rem);font-weight:400;color:#fff;line-height:1;margin-bottom:.6rem}
.proc-hero h1 em{font-style:italic;color:var(--sage)}
.proc-hero-sub{font-size:.88rem;color:rgba(255,255,255,.45);margin-bottom:1.5rem;max-width:420px;line-height:1.75}
.proc-hero-stats{display:flex;gap:1.5rem;margin-bottom:1.75rem;flex-wrap:wrap}
.proc-hero-img{width:180px;opacity:.88}

.stat-num{font-family:var(--serif);font-size:1.5rem;color:#fff;line-height:1}
.stat-label{font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:.15rem}

/* Quick facts strip */
.quick-facts{background:var(--dark);display:flex;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.07)}
.qf-item{flex:1;min-width:120px;padding:1rem 1.25rem;border-right:1px solid rgba(255,255,255,.07)}
.qf-item:last-child{border-right:none}
.qf-top{display:flex;align-items:center;gap:.4rem;margin-bottom:.35rem}
.qf-icon{font-size:.95rem;line-height:1;flex-shrink:0}
.qf-label{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.3)}
.qf-val{font-size:1.15rem;font-weight:500;color:#fff;line-height:1.1}

/* Body layout — flowchart + content */
.body-outer{background:var(--warm);padding:0 var(--pad)}
.body-wrap{display:grid;grid-template-columns:1fr 2fr;gap:0;max-width:1100px;margin:0 auto}

/* Flowchart column */
.flowchart-col{padding:2.5rem 2rem 2.5rem 0;border-right:1px solid var(--border)}
.col-label{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:1.4rem}
.vflow{display:flex;flex-direction:column;position:relative}
.vflow::before{content:'';position:absolute;left:17px;top:20px;bottom:20px;width:1.5px;background:linear-gradient(to bottom,var(--teal),var(--border));z-index:0}
.vf-step{display:flex;gap:1rem;align-items:flex-start;position:relative;z-index:1}
.vf-step+.vf-step{margin-top:1.5rem}
.vf-dot{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--warm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;line-height:1;transition:transform .2s}
.vf-dot.active{background:var(--teal);border-color:var(--teal)}
.vf-body{padding-top:.3rem}
.vf-when{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.15rem}
.vf-title{font-size:.9rem;font-weight:500;color:var(--ink);margin-bottom:.2rem}
.vf-detail{font-size:.78rem;color:var(--muted);line-height:1.5}

/* Content column */
.content-col{padding:2.5rem 0 2.5rem 2.5rem}
.info-card{background:#fff;border:1px solid var(--border);padding:1.1rem 1.3rem;margin-bottom:1rem}
.info-card:last-child{margin-bottom:0}
.info-card .card-title{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.7rem}
.quick-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}
.quick-list li{font-size:.85rem;color:#3a4c3f;display:flex;align-items:baseline;gap:.6rem;line-height:1.45}
.quick-list li .icon{font-size:.9rem;flex-shrink:0;width:1.2rem}
.numbered-list{list-style:none;padding:0;margin:0;counter-reset:steps;display:flex;flex-direction:column;gap:.5rem}
.numbered-list li{font-size:.85rem;color:#3a4c3f;display:flex;align-items:baseline;gap:.65rem;line-height:1.45;counter-increment:steps}
.numbered-list li::before{content:counter(steps);font-family:var(--serif);font-size:1.1rem;color:var(--teal);flex-shrink:0;line-height:1;min-width:16px;text-align:center}

/* Expect grid (3 cards) */
.expect-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}

/* Cost grid */
.cost-grid{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:start}
.cost-price-card{min-width:220px}

/* FAQ */
.faq-item{background:#fff;border:1px solid var(--border);margin-bottom:.5rem}
.faq-item button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:none;border:none;cursor:pointer;text-align:left;gap:1rem;min-height:48px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.faq-item .faq-q{font-size:.9rem;font-weight:500;color:var(--ink)}
.faq-item .faq-icon{font-size:1.2rem;color:var(--teal);flex-shrink:0;transition:transform .25s}
.faq-body{display:none;padding:0 1.25rem 1rem}
.faq-body p{font-size:.86rem;color:#3a4c3f;line-height:1.75}

/* Section wrapper — reusable max-width container */
.section-wrap{max-width:1100px;margin:0 auto}
.section-intro{margin-bottom:1.5rem}
.section-intro .section-label{margin-bottom:.4rem;border-bottom:none;padding-bottom:0}
.section-intro h2{font-family:var(--serif);font-size:clamp(1.5rem,3.5vw,2rem);font-weight:400;color:var(--ink);line-height:1.15}
.section-intro h2 em{font-style:italic;color:var(--teal)}

/* Expect cards (Before we operate) */
.expect-card{background:#fff;border:1px solid var(--border);padding:1.25rem 1.4rem}
.expect-card-label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:.75rem;font-weight:500}
.expect-card-label.warning{color:#8b3a2a}
.expect-card p,.expect-card-text{font-size:.88rem;color:#3a4c3f;line-height:1.75}
.expect-dark{grid-column:1/-1;background:var(--dark);padding:1.4rem 1.6rem;display:flex;align-items:flex-start;gap:1.5rem;flex-wrap:wrap}
.expect-dark-col{flex:1;min-width:220px}
.expect-dark-label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage);margin-bottom:.5rem;font-weight:500}
.expect-dark p{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.75}
.expect-quote-list{list-style:none;padding:0;margin:.65rem 0 0;display:flex;flex-direction:column;gap:.35rem}
.expect-quote-list li{font-size:.84rem;color:#3a4c3f;padding-left:1rem;position:relative;line-height:1.5;font-style:italic}
.expect-quote-list li::before{content:'"';position:absolute;left:0;color:var(--teal)}

/* Cost section */
.cost-section{background:var(--warm);padding:2.5rem var(--pad);border-top:1px solid var(--border)}
.cost-price-card{background:var(--dark);padding:1.5rem 2rem;min-width:240px}
.cost-range-label{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);margin-bottom:.5rem}
.cost-amount{font-family:var(--serif);font-size:2.4rem;color:#fff;line-height:1}
.cost-to{font-size:.75rem;color:rgba(255,255,255,.35);margin:.2rem 0 .75rem}
.cost-factors{background:#fff;border:1px solid var(--border);padding:1.25rem 1.4rem;align-self:stretch}
.cost-factors .card-title{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.85rem}
.cost-factor-row{display:flex;gap:1rem;align-items:flex-start;padding-bottom:.7rem;border-bottom:1px solid var(--border)}
.cost-factor-row:last-child{border-bottom:none;padding-bottom:0}
.cost-factor-label{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);font-weight:500;min-width:130px;padding-top:.1rem;flex-shrink:0}
.cost-factor-text{font-size:.85rem;color:#3a4c3f;line-height:1.6}
.disclaimer{font-size:.78rem;color:var(--muted);margin-top:1rem;line-height:1.65;border-left:2px solid var(--border);padding-left:.9rem}

/* FAQ section wrapper */
.faq-section{background:var(--cream);padding:2.5rem var(--pad);border-top:1px solid var(--border)}
.faq-list{display:flex;flex-direction:column;gap:.6rem}

/* ══════════════════════════════════
   BLOG PAGE
   ══════════════════════════════════ */
.scalpel-wrap{flex-shrink:0;width:clamp(55px,9vw,90px);align-self:stretch;display:flex;align-items:flex-end;padding-bottom:.25rem}
.scalpel-wrap img{width:100%;max-height:260px;object-fit:contain;object-position:bottom;opacity:.82;mix-blend-mode:luminosity}
.header-text{flex:1}

/* Blog header override — flex instead of grid */
.blog-header .header-inner{display:flex;align-items:flex-end;gap:2rem;position:relative;z-index:1}
.blog-header{position:relative;overflow:hidden}

/* Featured */
.featured{background:var(--cream);padding:3.5rem var(--pad);border-bottom:1px solid var(--border)}
.featured-card{max-width:860px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;background:var(--warm);border:1px solid var(--border)}
.featured-body{padding:2.5rem}
.post-tag{display:inline-block;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;padding:.2rem .65rem;background:#e8f0eb;color:#2a5c3a;margin-bottom:1rem}
.featured-title{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;line-height:1.2;margin-bottom:.75rem;color:var(--ink)}
.featured-title em{font-style:italic;color:var(--teal)}
.featured-excerpt{font-size:.85rem;color:var(--muted);line-height:1.85;margin-bottom:1.5rem}
.post-meta{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:1.25rem}
.read-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);font-weight:500;transition:gap .2s}
.read-link:hover{gap:.85rem}
.read-link::after{content:'→'}
.featured-visual{background:var(--dark);display:flex;align-items:center;justify-content:center;min-height:280px;overflow:hidden}
.featured-visual-inner{padding:2rem;text-align:center}
.featured-visual-label{font-family:var(--serif);font-size:1.6rem;font-weight:400;color:var(--sage);line-height:1.3;display:block;margin-bottom:.5rem}
.featured-visual-sub{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.3)}

/* Blog grid */
.blog-section{padding:3.5rem var(--pad);max-width:900px;margin:0 auto}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-top:1.5rem}
.blog-card{background:#fff;border:1px solid var(--border);display:flex;flex-direction:column;transition:border-color .2s,box-shadow .2s}
.blog-card:hover{border-color:var(--teal);box-shadow:0 4px 20px rgba(58,110,82,.08)}
.card-top{padding:1.75rem 1.75rem 0}
.card-tag{display:inline-block;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;padding:.2rem .65rem;background:#f0ece4;color:#5c4a2a;margin-bottom:.85rem}
.card-title{font-family:var(--serif);font-size:1.25rem;font-weight:400;line-height:1.25;margin-bottom:.6rem;color:var(--ink)}
.card-title em{font-style:italic;color:var(--teal)}
.card-excerpt{font-size:.8rem;color:var(--muted);line-height:1.75;margin-bottom:1rem}
.card-bottom{padding:.85rem 1.75rem 1.5rem;margin-top:auto;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-date{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.card-arrow{font-size:.8rem;color:var(--teal);transition:transform .2s}
.blog-card:hover .card-arrow{transform:translateX(4px)}
.coming-soon{opacity:.5;pointer-events:none}
.coming-badge{display:inline-block;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;padding:.15rem .55rem;background:var(--border);color:var(--muted)}

/* ══════════════════════════════════
   BLOG ARTICLES (gynecomastia-guide, why-cosmetic etc.)
   ══════════════════════════════════ */

/* Article body */
.article{max-width:720px;margin:0 auto;padding:3.5rem var(--pad)}
.blog-meta{display:flex;flex-wrap:wrap;gap:1.25rem;margin-top:1.5rem}
.blog-meta span{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.blog-meta strong{color:rgba(255,255,255,.55);font-weight:400}
.article .section-label{display:block;margin-top:2rem;margin-bottom:.75rem;padding-bottom:.4rem}
.article .section-heading{color:var(--dark)}
.article .prose p{font-size:.9rem;color:var(--muted);line-height:1.85;margin-bottom:.9rem}
.article .prose p:last-child{margin-bottom:0}
.prose strong{color:var(--ink);font-weight:500}
.prose ul{padding-left:1.1rem;margin-bottom:.9rem}
.prose ul li{font-size:.88rem;color:var(--muted);margin-bottom:4px;line-height:1.75}
.divider{border:none;border-top:1px solid var(--border);margin:2.5rem 0 0}
.sub-head{font-family:var(--sans);font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);margin:1.4rem 0 .5rem}

/* Highlight boxes */
.hl{padding:.9rem 1.1rem;margin:.75rem 0;border-left:3px solid}
.hl-label{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;display:block;margin-bottom:.5rem}
.hl-green{background:#edf4ef;border-color:var(--teal)}
.hl-green .hl-label{color:var(--teal)}
.hl-green p,.hl-green li{color:#243d2a;font-size:.86rem;line-height:1.8}
.hl-cream{background:var(--cream);border-color:var(--border)}
.hl-cream .hl-label{color:var(--muted)}
.hl-cream p,.hl-cream li{color:var(--ink);font-size:.86rem;line-height:1.8}
.hl-amber{background:#fef9ef;border-color:#c8922a}
.hl-amber .hl-label{color:#a07020}
.hl-amber p{color:#5c3f10;font-size:.88rem;line-height:1.85;margin:0}
.hl-dark{background:var(--dark2);border-color:var(--sage)}
.hl-dark .hl-label{color:var(--sage)}
.hl-dark p,.hl-dark li{color:rgba(255,255,255,.6);font-size:.86rem;line-height:1.8}
.hl ul{padding-left:1rem;margin:.25rem 0 0}
.hl ul li{margin-bottom:3px}

/* Pull quote */
.pull-quote{margin:2rem 0;padding:0 0 0 1.5rem;border-left:3px solid var(--teal)}
.pull-quote p{font-family:var(--serif);font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:400;font-style:italic;color:var(--dark);line-height:1.4;margin:0}
.pull-quote cite{display:block;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:.6rem;font-style:normal}

/* Points grid (why-cosmetic) */
.points{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin:1rem 0 1.5rem}
.point{background:var(--cream);border:1px solid var(--border);padding:1rem}
.point-num{font-family:var(--serif);font-size:2rem;color:var(--border);line-height:1;margin-bottom:.5rem}
.point-text{font-size:.82rem;color:var(--muted);line-height:1.7}
.point-text strong{color:var(--ink);font-weight:500;display:block;margin-bottom:.25rem}

/* Step list */
.steps{margin:.75rem 0 1.25rem}
.step-row{display:flex;gap:1rem;margin-bottom:.85rem;align-items:flex-start}
.step-num{font-family:var(--serif);font-size:1.1rem;color:var(--teal);min-width:1.5rem;flex-shrink:0;line-height:1.4}
.step-body{font-size:.88rem;color:var(--muted);line-height:1.75}
.step-body strong{color:var(--ink);font-weight:500}

/* Grade table (gynecomastia-guide) */
.grade-table{width:100%;border-collapse:collapse;margin:.75rem 0 1.25rem;font-size:.84rem}
.grade-table th{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:7px 10px;border-bottom:1px solid var(--border);text-align:left;font-weight:400}
.grade-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:top;color:var(--muted);line-height:1.65}
.grade-table tr:last-child td{border-bottom:none}
.grade-table tr:hover td{background:var(--cream)}
.grade-badge{display:inline-block;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:2px 9px;border:1px solid;white-space:nowrap}
.grade-i{background:#edf4ef;color:var(--teal);border-color:var(--teal)}
.grade-iia{background:var(--cream);color:var(--btn);border-color:var(--border)}
.grade-iib{background:var(--cream);color:var(--ink);border-color:var(--border)}
.grade-iii{background:var(--dark2);color:var(--sage);border-color:#2d4a35}
.grade-pseudo{background:var(--warm);color:var(--muted);border-color:var(--border)}
.article .card-val-sm{font-size:1rem}
.hl .hl-note{margin-top:.5rem;font-size:.8rem}

/* Article stat cards (scoped to avoid collision with procedure cards) */
.article .card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin:.75rem 0 1rem}
.article .card{background:var(--cream);padding:.85rem 1rem;border:1px solid var(--border);overflow:visible}
.article .card:hover{border-color:var(--border);box-shadow:none}
.article .card-label{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.article .card-val{font-family:var(--serif);font-size:1.1rem;color:var(--dark)}
.article .card-sub{font-size:.78rem;color:var(--muted);margin-top:3px;line-height:1.6}

/* Info box & pills */
.info-box{border:1px solid var(--border);padding:.85rem 1rem;margin:.65rem 0}
.info-box p{font-size:.82rem;color:var(--muted);margin-bottom:.4rem}
.pill{display:inline-block;font-size:.68rem;letter-spacing:.06em;padding:2px 10px;margin:2px 2px 2px 0;border:1px solid var(--teal);color:var(--teal)}

/* Two-col layout (article) */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:.75rem 0}

/* Recovery timeline */
.timeline{margin:.75rem 0 1.25rem}
.tl-row{display:flex;gap:12px;margin-bottom:9px;align-items:flex-start}
.tl-time{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);background:var(--cream);border:1px solid var(--border);padding:3px 8px;min-width:76px;text-align:center;flex-shrink:0;margin-top:1px}
.tl-body{font-size:.86rem;color:var(--muted);line-height:1.65}

/* Alert box */
.alert-box{border-left:3px solid var(--teal);background:#edf4ef;padding:.8rem 1.1rem;margin:.85rem 0}
.alert-box .al{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);display:block;margin-bottom:.4rem}
.alert-box p{color:#243d2a;font-size:.86rem;margin:0}

/* Final remarks box */
.final-box{background:var(--dark);padding:2rem 2.25rem;margin-top:2rem}
.final-box .fr-label{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage);display:block;margin-bottom:.75rem}
.final-box h2{font-family:var(--serif);font-size:clamp(1.4rem,3vw,1.9rem);font-weight:400;color:#fff;margin-bottom:1rem;line-height:1.2}
.final-box h2 em{font-style:italic;color:var(--sage)}
.final-box p{font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.85;margin-bottom:.75rem}
.final-box p:last-child{margin-bottom:0}
.final-box strong{color:rgba(255,255,255,.75);font-weight:400}

/* Author portrait */
.author-portrait{text-align:center;margin:2rem 0 2.5rem;position:relative}
.author-portrait img{width:clamp(200px,55%,340px);opacity:.92;mix-blend-mode:multiply}
.portrait-caption{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}

/* Footnote */
.footnote{font-size:.72rem;color:var(--muted);margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border);font-style:italic}

/* ══════════════════════════════════
   CTA (shared across pages)
   ══════════════════════════════════ */
.cta{background:var(--dark);padding:4rem var(--pad);text-align:center}
.cta-heading{font-family:var(--serif);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:400;margin-bottom:1rem;color:#fff}
.cta-heading em{font-style:italic;color:var(--sage)}
.cta h2{font-family:var(--serif);font-size:clamp(1.6rem,4vw,2.2rem);font-weight:400;color:#fff;margin-bottom:.5rem}
.cta h2 em{font-style:italic;color:var(--sage)}
.cta p{font-size:.84rem;color:rgba(255,255,255,.38);margin-bottom:1.4rem}
.cta-desc{font-size:.88rem;color:rgba(255,255,255,.45);max-width:400px;margin:0 auto 2rem;line-height:1.8}

/* ══════════════════════════════════
   OTHER PROCEDURES (shared)
   ══════════════════════════════════ */
.other-procs{background:var(--cream);padding:1.75rem var(--pad);border-top:1px solid var(--border)}
.other-procs-inner{max-width:800px;margin:0 auto}
.other-label{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.85rem}
.other-grid{display:flex;flex-wrap:wrap;gap:.6rem}
.other-link{font-size:.76rem;padding:.35rem .9rem;border:1px solid var(--border);color:var(--ink);background:#fff;transition:background .2s,border-color .2s}
.other-link:hover{background:var(--cream);border-color:var(--teal)}

/* ══════════════════════════════════
   FOOTER
   ══════════════════════════════════ */
footer{background:var(--dark);padding:1.25rem var(--pad);padding-bottom:max(1.25rem,env(safe-area-inset-bottom))}
.ft-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.ft-logo{font-family:var(--serif);font-size:1rem;color:#fff}
.ft-logo em{font-style:italic;color:var(--sage)}
.ft-nav{display:flex;gap:1.25rem;flex-wrap:wrap}
.ft-nav a{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);transition:color .2s}
.ft-nav a:hover{color:#fff}
.ft-bottom{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.ft-copy{font-size:.6rem;color:rgba(255,255,255,.22)}
.ft-note{font-size:.58rem;color:rgba(255,255,255,.15);font-style:italic}

/* ══════════════════════════════════
   RESPONSIVE — Mobile First
   ══════════════════════════════════ */

/* Tablet */
@media(max-width:860px){
  .body-wrap{grid-template-columns:1fr}
  .flowchart-col{border-right:none;border-bottom:1px solid var(--border);padding:2rem 0}
  .content-col{padding:2rem 0}
}

@media(max-width:768px){
  .about{grid-template-columns:1fr;text-align:center}
  .about-img{justify-content:center;margin-bottom:2rem}
  .about-img img{max-width:240px}
  .about-txt{padding-left:0}
  .quals{justify-content:center}
  .about-stats{justify-content:center}
  .header-inner{grid-template-columns:1fr}
  .header-img{display:none}
  .two-col-inner{grid-template-columns:1fr}
  .featured-card{grid-template-columns:1fr}
  .featured-visual{min-height:180px;order:-1}
  .contact-grid{grid-template-columns:1fr}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:700px){
  .expect-grid{grid-template-columns:1fr}
}

@media(max-width:620px){
  .cost-grid{grid-template-columns:1fr}
  .cost-price-card{min-width:unset}
}

/* Mobile */
@media(max-width:600px){
  .nav-links{display:none;flex-direction:column;position:fixed;top:60px;left:0;right:0;background:var(--dark);padding:1.5rem var(--pad);align-items:flex-start;gap:1.25rem}
  .nav-links.open{display:flex}
  .menu-btn{display:flex}
  .hero-stats{gap:1.25rem}
  .stat-n{font-size:1.4rem}
  .proc-hero-inner{grid-template-columns:1fr}
  .proc-hero-img{display:none}
  .quick-facts{flex-direction:column}
  .qf-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
  .blog-grid{grid-template-columns:1fr}
  .page-header-inner{flex-direction:column;text-align:center}
  .page-surgeon{order:-1}
  .cards{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .points{grid-template-columns:1fr}
}

@media(max-width:480px){
  .scalpel-wrap{width:44px}
  .consult-header{grid-template-columns:1fr}
  .page-header-img{display:none}
  input,textarea,select{font-size:16px !important}
  .insta-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:380px){
  .hero-stats{gap:.85rem}
  .stat-num{font-size:1.2rem}
}

@media(max-width:360px){
  .qf-val{font-size:.95rem}
  .qf-label{font-size:.52rem}
}

/* ── TOUCH & iOS SAFE AREA ── */
a,button,.faq-item button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.cta,.proc-hero{padding-left:max(var(--pad),env(safe-area-inset-left));padding-right:max(var(--pad),env(safe-area-inset-right))}
