/* ============================================================
   RTPC — Rosemarie Tully, P.C.  ·  counsel to the creative
   Shared design system
   ============================================================ */

:root{
  /* Brand */
  --navy:#272361;        /* deep navy — ink + emblem core   */
  --blue:#2B388F;        /* royal blue — brand bar device    */
  --coral:#EF4331;       /* coral — accent                   */
  --coral-deep:#D8381F;

  /* Surfaces */
  --paper:#FAF7F1;       /* warm paper                       */
  --paper-2:#F2EDE3;     /* secondary warm surface           */
  --cream:#EFE9DC;
  --white:#ffffff;

  /* Ink */
  --ink:#1c1936;         /* primary text                     */
  --ink-2:#383453;       /* secondary text                   */
  --ink-3:#5d5a76;       /* muted                            */
  --line:#e3ddd0;        /* hairlines on paper               */
  --line-soft:rgba(39,35,97,.12);

  /* Type */
  --serif:"Spectral", Georgia, "Times New Roman", serif;
  --display:"Spectral", Georgia, serif;
  --sans:"Source Sans 3", "Helvetica Neue", Arial, sans-serif;
  --script:"Yellowtail", "Brush Script MT", cursive;

  --maxw:1180px;
  --gutter:clamp(20px,5vw,64px);

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* type variant: elegant display */
:root[data-type="cormorant"]{
  --display:"Cormorant Garamond", Georgia, serif;
  --serif:"Cormorant Garamond", Georgia, serif;
}

/* surface theme variants (set on <html>, synced across pages) */
:root[data-theme="white"]{
  --paper:#ffffff;
  --paper-2:#f3f3f6;
  --cream:#ececf1;
  --line:#e6e6ec;
  --line-soft:rgba(39,35,97,.10);
}
:root[data-theme="cream"]{
  --paper:#F4EEE2;
  --paper-2:#EAE2D1;
  --cream:#E2D8C3;
  --line:#dccfb8;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background-color:var(--paper);
  background-image:
    radial-gradient(1100px 620px at 100% -8%, rgba(43,56,143,.06), transparent 58%),
    radial-gradient(1000px 720px at -12% 108%, rgba(239,67,49,.045), transparent 55%);
  background-attachment:fixed;
  background-repeat:no-repeat;
  color:var(--ink);
  font-family:var(--sans);
  font-size:18px;
  line-height:1.62;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* fine paper grain — subtle texture over light areas */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--coral);color:#fff}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1380px;margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.bleed{width:100%}

/* ---------- Type scale ---------- */
.display{
  font-family:var(--display);
  font-weight:600;
  line-height:1.02;
  letter-spacing:-.012em;
  font-size:clamp(2.7rem,7vw,5.6rem);
  color:var(--navy);
  text-wrap:balance;
}
:root[data-type="cormorant"] .display{font-weight:600;letter-spacing:0}
.h1{font-family:var(--display);font-weight:600;font-size:clamp(2.1rem,4.6vw,3.5rem);line-height:1.06;letter-spacing:-.01em;color:var(--navy);text-wrap:balance;margin:0}
.h2{font-family:var(--display);font-weight:600;font-size:clamp(1.7rem,3.3vw,2.6rem);line-height:1.12;letter-spacing:-.008em;color:var(--navy);text-wrap:balance;margin:0}
.h3{font-family:var(--display);font-weight:600;font-size:clamp(1.25rem,2vw,1.6rem);line-height:1.2;color:var(--navy);margin:0}
.lead{font-size:clamp(1.15rem,1.7vw,1.4rem);line-height:1.55;color:var(--ink-2);font-weight:400}
.prose p{margin:0 0 1.1em;max-width:64ch;color:var(--ink-2)}
.prose p:last-child{margin-bottom:0}

.eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--coral);
  display:inline-flex;align-items:center;gap:.7em;
  margin:0;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--coral);display:inline-block}
.eyebrow--plain::before{display:none}
.eyebrow--navy{color:var(--navy)}
.eyebrow--navy::before{background:var(--navy)}
.eyebrow--light{color:#fff}
.eyebrow--light::before{background:var(--coral)}

.script{font-family:var(--script);color:var(--coral);font-weight:400;line-height:1}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--coral);--fg:#fff;--bd:var(--coral);
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-weight:600;font-size:.98rem;letter-spacing:.01em;
  padding:.85em 1.6em;border-radius:2px;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);
  cursor:pointer;transition:transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease),box-shadow .25s var(--ease);
  white-space:nowrap;
}
.btn:hover{background:var(--coral-deep);border-color:var(--coral-deep);transform:translateY(-2px);box-shadow:0 10px 24px -12px rgba(216,56,31,.65)}
.btn .arw{transition:transform .25s var(--ease)}
.btn:hover .arw{transform:translateX(4px)}
.btn--outline{--bg:transparent;--fg:var(--navy);--bd:var(--navy)}
.btn--outline:hover{--fg:#fff;background:var(--navy);border-color:var(--navy);box-shadow:none}
.btn--ghost-light{--bg:transparent;--fg:#fff;--bd:rgba(255,255,255,.5)}
.btn--ghost-light:hover{background:#fff;color:var(--navy);border-color:#fff;box-shadow:none}
.btn--lg{padding:1.05em 2em;font-size:1.05rem}

.tlink{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--navy);border-bottom:2px solid var(--coral);padding-bottom:2px;transition:gap .25s var(--ease),color .2s}
.tlink:hover{gap:.85em;color:var(--coral)}
.tlink .arw{transition:transform .25s var(--ease)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 86%,transparent);backdrop-filter:blur(12px) saturate(1.2);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand__mark{width:60px;height:48px;flex:none;object-fit:contain;margin-left:-6px}
.brand__text{display:flex;flex-direction:column;line-height:1;min-width:0}
.brand__name{font-family:var(--display);font-weight:600;color:var(--navy);font-size:1.05rem;letter-spacing:.03em;white-space:nowrap}
.brand__tag{font-family:var(--script);color:var(--coral);font-size:.95rem;margin-top:2px;white-space:nowrap}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-family:var(--sans);font-weight:500;font-size:1rem;color:var(--ink);position:relative;padding:4px 0;transition:color .2s}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--coral);transition:right .3s var(--ease)}
.nav__links a:hover{color:var(--navy)}
.nav__links a:hover::after,.nav__links a[aria-current="page"]::after{right:0}
.nav__links a[aria-current="page"]{color:var(--navy);font-weight:600}
.nav__cta{display:flex;align-items:center;gap:16px}
.nav__phone{font-weight:600;color:var(--navy);white-space:nowrap}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--navy)}
.nav__toggle svg{display:block}

/* mobile menu */
.mnav{display:none}
@media(max-width:1024px){
  .nav__links,.nav__cta .btn,.nav__phone{display:none}
  .nav__toggle{display:block}
  .mnav{display:block;position:fixed;inset:78px 0 auto 0;background:var(--paper);border-bottom:1px solid var(--line);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.3s var(--ease);z-index:55;box-shadow:0 30px 50px -30px rgba(39,35,97,.4)}
  .mnav.open{transform:none;opacity:1;pointer-events:auto}
  .mnav a{display:block;padding:16px var(--gutter);font-size:1.15rem;font-family:var(--display);color:var(--navy);border-top:1px solid var(--line)}
  .mnav .btn{margin:18px var(--gutter) 26px;display:inline-flex}
}

/* ---------- Brand bar device ---------- */
.brandbar{background:var(--blue);color:#fff;position:relative;overflow:hidden}
.brandbar--navy{background:var(--navy)}
.bartrim{height:6px;background:var(--coral)}

/* watermark emblem */
.wm{position:absolute;pointer-events:none;opacity:.06}

/* ---------- Footer ---------- */
.footer{background:var(--navy);color:#cfcde6}
.footer a{color:#cfcde6;transition:color .2s}
.footer a:hover{color:#fff}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;padding-block:72px}
.footer__lock{width:min(340px,80%)}
.footer__col h4{font-family:var(--sans);font-weight:600;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin:0 0 18px}
.footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:26px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.9rem;color:#9d9abe}
@media(max-width:760px){.footer__grid{grid-template-columns:1fr;gap:38px;padding-block:54px}}

/* ---------- Practice list / cards ---------- */
.plist{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.pitem{border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;padding:30px 6px;transition:padding .3s var(--ease),background .3s}
.pitem__num{font-family:var(--display);font-size:1.05rem;color:var(--coral);font-weight:600;font-variant-numeric:tabular-nums}
.pitem__name{font-family:var(--display);font-weight:600;color:var(--navy);font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.1}
.pitem__desc{color:var(--ink-2);max-width:46ch;font-size:1.02rem}
.pitem__arw{color:var(--navy);opacity:0;transform:translateX(-8px);transition:.3s var(--ease)}
.pitem:hover{background:linear-gradient(90deg,transparent,rgba(43,56,143,.04));padding-inline:22px}
.pitem:hover .pitem__arw{opacity:1;transform:none;color:var(--coral)}
@media(max-width:760px){.pitem{grid-template-columns:auto 1fr;gap:16px}.pitem__desc{display:none}.pitem__arw{display:none}}

/* card grid variant */
.pcards{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border:1px solid var(--line)}
.pcard{background:var(--paper);padding:38px 34px;min-height:240px;display:flex;flex-direction:column;transition:.35s var(--ease);position:relative}
.pcard:hover{background:var(--white)}
.pcard__num{font-family:var(--display);color:var(--coral);font-weight:600;margin-bottom:auto}
.pcard h3{margin:0 0 12px;font-size:1.45rem}
.pcard p{margin:0;color:var(--ink-2);font-size:1rem}
.pcard__bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--coral);transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease)}
.pcard:hover .pcard__bar{transform:scaleY(1)}
@media(max-width:900px){.pcards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pcards{grid-template-columns:1fr}}

/* ---------- Stat / values ---------- */
.statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft)}
.stat{background:var(--paper);padding:8px 24px 8px 0}
.stat__n{font-family:var(--display);font-weight:600;color:var(--navy);font-size:clamp(2.2rem,4vw,3rem);line-height:1}
.stat__l{color:var(--ink-2);font-size:.98rem;margin-top:6px}
@media(max-width:680px){.statrow{grid-template-columns:1fr;gap:0}.stat{padding:18px 0;border-bottom:1px solid var(--line)}}

/* ---------- Placeholder media ---------- */
.ph{position:relative;background:
   repeating-linear-gradient(135deg,var(--paper-2),var(--paper-2) 11px,var(--cream) 11px,var(--cream) 22px);
   border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden}
.ph__tag{font-family:var(--sans);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);background:var(--paper);padding:7px 13px;border:1px solid var(--line)}
.ph--navy{background:repeating-linear-gradient(135deg,#23204f,#23204f 11px,#2a2659 11px,#2a2659 22px);border-color:rgba(255,255,255,.12)}
.ph--navy .ph__tag{color:#b8b5d6;background:#23204f;border-color:rgba(255,255,255,.16)}

/* ---------- Misc ---------- */
.rule{height:1px;background:var(--line);border:0;margin:0}
.kicker-line{width:54px;height:3px;background:var(--coral);border:0;margin:0 0 26px}
.fadeup{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.fadeup.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.fadeup{opacity:1;transform:none;transition:none}}

.tag-pill{display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:600;font-size:.8rem;letter-spacing:.04em;color:var(--navy);background:var(--paper-2);border:1px solid var(--line);padding:.45em .9em;border-radius:100px}

/* ---------- Article (Insights detail) ---------- */
.art-hero{background:var(--paper);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.art-hero__inner{max-width:820px;margin:0 auto;padding-inline:var(--gutter);padding-block:clamp(40px,6vw,76px)}
.art-back{display:flex;width:fit-content;align-items:center;gap:.5em;font-weight:600;font-size:.9rem;color:var(--ink-3);margin-bottom:22px;transition:color .2s,gap .25s var(--ease);white-space:nowrap}
.art-back:hover{color:var(--coral);gap:.8em}
.art-hero h1{font-family:var(--display);font-weight:600;color:var(--navy);font-size:clamp(2.1rem,4.6vw,3.4rem);line-height:1.08;letter-spacing:-.01em;margin:16px 0 0;text-wrap:balance}
.art-meta{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-top:22px;color:var(--ink-3);font-size:.92rem}
.art-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--coral)}
.art-figure{max-width:980px;margin:clamp(28px,4vw,48px) auto 0;padding-inline:var(--gutter)}
.art-figure .ph{aspect-ratio:16/8;border-radius:3px}

.article{max-width:720px;margin:0 auto;padding-inline:var(--gutter);padding-block:clamp(40px,6vw,72px)}
.article > *{max-width:68ch}
.article p{font-size:1.16rem;line-height:1.72;color:var(--ink-2);margin:0 0 1.35em}
.article .art-lead{font-family:var(--display);font-weight:500;font-size:clamp(1.3rem,2.2vw,1.6rem);line-height:1.4;color:var(--navy);margin-bottom:1.1em}
.article h2{font-family:var(--display);font-weight:600;color:var(--navy);font-size:clamp(1.5rem,2.8vw,2rem);line-height:1.15;margin:1.9em 0 .5em}
.article h3{font-family:var(--display);font-weight:600;color:var(--navy);font-size:1.3rem;margin:1.6em 0 .4em}
.article a{color:var(--navy);font-weight:600;border-bottom:2px solid var(--coral);padding-bottom:1px}
.article a:hover{color:var(--coral)}
.article ol,.article ul{margin:0 0 1.5em;padding-left:1.3em;color:var(--ink-2);font-size:1.12rem;line-height:1.65}
.article li{margin-bottom:.7em;padding-left:.3em}
.article li::marker{color:var(--coral);font-weight:700}
.article strong{color:var(--ink);font-weight:600}
.article .term{font-family:var(--display);font-weight:600;color:var(--navy)}
.article blockquote{margin:1.8em 0;padding:24px 28px;background:var(--paper-2);border-left:4px solid var(--coral);border-radius:0 3px 3px 0}
.article blockquote p{font-size:1.04rem;line-height:1.6;color:var(--ink-2);margin:0;font-style:italic}
.article .art-rule{height:1px;background:var(--line);border:0;margin:2.4em 0;max-width:none}
.article .art-end{display:flex;align-items:center;gap:14px;margin-top:2.4em;color:var(--ink-3);font-size:.95rem}
.article .art-end .em{width:auto;height:30px;flex:none;object-fit:contain;opacity:.8}
