:root{
  --gold:#cba14f;
  --gold-soft:#dcc086;
  --gold-bright:#f0d79a;
  --black:#0a0a0a;
  --ink:#101010;
  --panel:#171511;
  --panel-2:#1e1b16;
  --panel-hi:#26221a;
  --line:rgba(203,161,79,0.34);
  --line-strong:rgba(203,161,79,0.55);
  --line-soft:rgba(255,255,255,0.10);
  --white:#f7f4ec;
  --text:#e3ddcf;       /* readable body text */
  --muted:#b3ad9d;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  /* Round-2: shared layout + depth tokens */
  --content-max:1180px;   /* page content cap */
  --grid-max:1040px;      /* centered card-grid cap (keeps cards from over-stretching) */
  --card-shadow:0 18px 40px -26px rgba(0,0,0,0.9);
  --card-shadow-hover:0 34px 68px -28px rgba(0,0,0,0.95);
  --gold-glow:0 0 0 1px rgba(203,161,79,0.55), 0 24px 60px -30px rgba(203,161,79,0.35);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--black);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;position:relative;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(1100px 560px at 50% -8%, rgba(203,161,79,0.16), transparent 62%),
    radial-gradient(760px 640px at 100% 110%, rgba(203,161,79,0.08), transparent 60%),
    radial-gradient(900px 700px at 0% 30%, rgba(203,161,79,0.05), transparent 55%);}
body::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.wrap{position:relative;z-index:1;max-width:var(--content-max);margin:0 auto;padding:0 28px;}

/* ── Top bar ── */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:24px 0 16px;gap:14px;flex-wrap:wrap;}
.topbar-left{display:flex;align-items:center;gap:18px;}
.mark{display:flex;align-items:center;gap:13px;}
.monogram{width:40px;height:40px;flex:none;position:relative;border:1px solid var(--gold);transform:rotate(45deg);display:flex;align-items:center;justify-content:center;}
.monogram::after{content:'';position:absolute;inset:5px;border:1px solid rgba(203,161,79,0.4);}
.monogram span{transform:rotate(-45deg);font-family:var(--serif);font-weight:700;font-size:19px;color:var(--gold-bright);}
.mark-text{display:flex;flex-direction:column;line-height:1.05;}
.mark-text b{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:0.5px;color:var(--white);}
.mark-text small{font-size:9px;letter-spacing:3.4px;text-transform:uppercase;color:var(--gold);margin-top:3px;}
.ref-chip{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-soft);border:1px solid var(--line);border-radius:999px;padding:7px 14px;white-space:nowrap;background:rgba(203,161,79,0.05);}
.ref-chip b{color:var(--gold-bright);font-weight:600;letter-spacing:1.5px;}

/* ── Screens ── */
.screen{animation:rise .5s cubic-bezier(.16,1,.3,1) both;}
.screen.active{display:block;}
.screen:not(.active){display:none!important;}
@keyframes rise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}

.eyebrow{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:600;}
.display{font-family:var(--serif);font-weight:600;line-height:1.02;letter-spacing:-0.5px;font-size:clamp(44px,7vw,82px);color:var(--white);margin:16px 0 0;}
.display .accent{color:var(--gold-bright);font-style:italic;font-weight:500;}
/* Directive 2: bigger, more legible body copy across the page. */
.lede{color:var(--text);font-weight:300;font-size:clamp(16.5px,1.6vw,20px);line-height:1.66;max-width:600px;margin-top:20px;}

/* ── SERVICES PAGE (landing) ── */
/* Directive 1: cap + center the whole services column so nothing left-aligns
   awkwardly on wide screens. Header copy, card groups, and assurance row all
   share one centered column. */
.svc-head-row{padding-top:10px;margin:0 auto 22px;max-width:var(--grid-max);text-align:center;}
.svc-head-row .eyebrow{justify-content:center;}
.svc-head-row .display{margin-left:auto;margin-right:auto;}
.svc-head-row .lede{margin-left:auto;margin-right:auto;text-align:center;max-width:660px;}

/* Card groups: each category block centered as a group, capped width. */
.svc-groups{display:block;}
.cat{margin:56px auto 0;max-width:var(--grid-max);}
.cat:first-child{margin-top:46px;}

/* Directive 3: the category labels are now PROMINENT section headings, not
   tiny eyebrows. Large serif, gold, with a divider rule that clearly
   announces each section. */
.cat-label{font-family:var(--serif);font-size:clamp(30px,4.4vw,44px);font-weight:600;line-height:1.05;letter-spacing:0.2px;text-transform:none;color:var(--gold-bright);margin-bottom:26px;display:flex;align-items:center;gap:20px;}
.cat-label::before{content:'';flex:none;width:34px;height:2px;background:linear-gradient(90deg,var(--gold),rgba(203,161,79,0.15));border-radius:2px;}
.cat-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent);}

/* Directive 1: centered tracks. fit (not fill) so a lonely last card stays its
   natural width instead of stretching; the grid itself is centered. */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,400px));gap:24px;justify-content:center;}

/* Directives 2 + 4: bigger type, more depth + figure/ground separation,
   warmer layered gold, refined borders, confident spacing — a premium,
   clearly-tappable service menu. */
.svc{position:relative;display:flex;flex-direction:column;
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(203,161,79,0.10), transparent 55%),
    linear-gradient(168deg,var(--panel-hi),var(--panel) 62%,#13110d);
  border:1px solid var(--line);border-radius:16px;padding:34px 32px 28px;cursor:pointer;overflow:hidden;
  box-shadow:var(--card-shadow);
  transition:transform .26s cubic-bezier(.16,1,.3,1),border-color .26s,box-shadow .26s,background .26s;will-change:transform;}
/* top gold hairline + inner highlight = layered, lit-from-above depth */
.svc::before{content:'';position:absolute;left:0;right:0;top:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(203,161,79,0.65),transparent);
  opacity:.5;transition:opacity .26s;}
.svc::after{content:'';position:absolute;inset:0;border-radius:16px;pointer-events:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.06),inset 0 0 60px -30px rgba(203,161,79,0.18);}
.svc:hover,.svc:focus-within{transform:translateY(-7px);border-color:var(--gold);
  box-shadow:var(--card-shadow-hover),var(--gold-glow);
  background:
    radial-gradient(120% 90% at 0% 0%, rgba(203,161,79,0.16), transparent 55%),
    linear-gradient(168deg,#2b261d,#1a1712 62%,#15120d);}
.svc:hover::before,.svc:focus-within::before{opacity:1;}
.svc-top{display:flex;align-items:center;gap:16px;margin-bottom:20px;}
.svc-badge{width:64px;height:64px;flex:none;border-radius:16px;background:linear-gradient(160deg,rgba(203,161,79,0.28),rgba(203,161,79,0.04));border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:var(--gold-bright);box-shadow:inset 0 1px 0 rgba(255,255,255,0.10),0 8px 18px -12px rgba(0,0,0,0.8);transition:box-shadow .26s,border-color .26s;}
.svc:hover .svc-badge{box-shadow:inset 0 1px 0 rgba(255,255,255,0.14),0 10px 22px -10px rgba(203,161,79,0.5);}
.svc-badge svg{width:34px;height:34px;}
.svc-tag{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--gold-bright);background:rgba(203,161,79,0.16);border:1px solid var(--line-strong);border-radius:999px;padding:6px 12px;white-space:nowrap;}
.svc h4{font-family:var(--serif);font-size:clamp(28px,2.4vw,33px);font-weight:700;line-height:1.06;color:#fff;margin-bottom:12px;letter-spacing:0.2px;}
.svc p{color:var(--text);font-size:16px;font-weight:400;line-height:1.62;flex:1;}
.svc-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:24px;padding-top:18px;border-top:1px solid var(--line-soft);}
.svc-price{font-size:15px;color:var(--gold-soft);font-weight:500;}
.svc-price b{color:#fff;font-weight:700;font-size:19px;}
.svc-cta{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;color:#1a1407;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-radius:999px;padding:12px 22px;transition:gap .2s,box-shadow .2s;box-shadow:0 10px 24px -10px rgba(203,161,79,0.85);}
.svc:hover .svc-cta{gap:12px;box-shadow:0 14px 30px -10px rgba(203,161,79,1);}

/* Directive 1: assurance row centered + capped, matching the card column. */
.assure{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:var(--grid-max);margin:84px auto 0;padding-top:48px;border-top:1px solid var(--line-soft);text-align:center;}
.assure div h5,.assure-item h5{font-family:var(--serif);font-size:22px;color:var(--white);margin-bottom:9px;}
.assure div p,.assure-item p{color:var(--muted);font-size:14.5px;font-weight:300;line-height:1.62;}

/* ── Shared form fields (used by the service forms + the partner dashboard's
   pd-* login, which layers .pd-field on top of .field) ── */
.field{margin-bottom:17px;}
.field label{display:block;font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--gold-soft);margin-bottom:9px;font-weight:600;}
.field input,.field select,.field textarea{width:100%;background:#0c0b0a;border:1px solid var(--line-soft);border-radius:4px;padding:14px 15px;color:var(--white);font-family:var(--sans);font-size:14.5px;transition:border-color .2s,box-shadow .2s;}
.field textarea{min-height:104px;resize:vertical;line-height:1.55;}
.field input::placeholder,.field textarea::placeholder{color:#615c52;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(203,161,79,0.12);}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23cba14f' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;padding-right:38px;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1407;font-weight:700;font-size:14px;letter-spacing:0.3px;border:none;border-radius:4px;padding:15px 30px;cursor:pointer;width:100%;transition:transform .15s ease,box-shadow .25s ease,filter .2s;box-shadow:0 14px 34px -14px rgba(203,161,79,0.7);will-change:transform;}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05);box-shadow:0 18px 40px -14px rgba(203,161,79,0.85);}
.btn:active{transform:translateY(0);}
.btn.ghost{background:transparent;color:var(--gold-bright);border:1px solid var(--line);box-shadow:none;width:auto;padding:13px 24px;}
.btn.ghost:hover{background:rgba(203,161,79,0.07);filter:none;}

/* ── Form screen ── */
.form-screen{padding-top:14px;}
.back{display:inline-flex;align-items:center;gap:9px;background:none;border:none;color:var(--gold-soft);cursor:pointer;font-size:12.5px;letter-spacing:1.4px;text-transform:uppercase;padding:8px 0;margin-bottom:8px;transition:gap .2s,color .2s;}
.back:hover{gap:13px;color:var(--gold-bright);}
.form-shell{display:grid;grid-template-columns:0.82fr 1.18fr;gap:48px;align-items:start;margin-top:12px;}
.form-aside .form-badge{width:56px;height:56px;border-radius:14px;background:linear-gradient(160deg,rgba(203,161,79,0.22),rgba(203,161,79,0.05));border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold-bright);margin-bottom:18px;}
.form-aside .form-badge svg{width:30px;height:30px;}
.form-aside h2{font-family:var(--serif);font-size:clamp(30px,4vw,44px);font-weight:600;line-height:1.05;color:var(--white);}
.form-aside p{color:var(--muted);font-weight:300;font-size:15px;line-height:1.65;margin-top:15px;}
.aside-points{margin-top:24px;display:flex;flex-direction:column;gap:13px;}
.aside-points span{display:flex;gap:12px;font-size:13px;color:var(--text);font-weight:300;line-height:1.5;}
.aside-points span::before{content:'';flex:none;width:6px;height:6px;margin-top:6px;background:var(--gold);transform:rotate(45deg);}
.form-card{background:linear-gradient(180deg,var(--panel-2),var(--ink));border:1px solid var(--line-soft);border-top:1px solid var(--line);border-radius:6px;padding:32px 30px;box-shadow:0 40px 90px -40px rgba(0,0,0,0.9);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:560px){.form-row{grid-template-columns:1fr;}}
.upload{display:block;border:1px dashed var(--line);border-radius:4px;padding:20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;}
.upload:hover{border-color:var(--gold);background:rgba(203,161,79,0.04);}
.upload .ut{font-size:13px;color:var(--gold-soft);}
.upload .uh{font-size:11px;color:#736e64;margin-top:5px;}
.thumbs{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px;}
.thumb{position:relative;width:58px;height:58px;border-radius:4px;overflow:hidden;border:1px solid var(--line-soft);}
.thumb img{width:100%;height:100%;object-fit:cover;}
.thumb button{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;border:none;background:rgba(0,0,0,0.75);color:#fff;cursor:pointer;font-size:12px;line-height:1;}
.success{display:none;text-align:center;padding:32px 20px;}
.success.show{display:block;animation:rise .5s ease both;}
.success .seal{width:60px;height:60px;margin:0 auto 18px;border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-bright);}
.success h3{font-family:var(--serif);font-size:28px;font-weight:600;color:var(--white);}
.success p{color:var(--muted);font-weight:300;font-size:14.5px;margin-top:10px;line-height:1.6;max-width:400px;margin:10px auto 0;}

/* gate-note: fine print under forms (was inline in HTML — now a class) */
.gate-note{margin-top:14px;font-size:11.5px;color:#8c8676;text-align:center;line-height:1.5;}
.gate-note b{color:var(--gold-soft);font-weight:600;}

/* ── PR MARKETPLACE ── */
.pr-screen{padding-top:14px;}
.pr-intro{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:22px;}
.pr-intro .l h2{font-family:var(--serif);font-size:clamp(30px,4.4vw,48px);font-weight:600;color:var(--white);line-height:1.04;}
.pr-intro .l p{color:var(--muted);font-weight:300;font-size:14.5px;margin-top:10px;max-width:540px;line-height:1.6;}
.pr-count{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--gold-soft);white-space:nowrap;}
.pr-count b{color:var(--gold-bright);}
.pr-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:14px;}
.pr-search{flex:1;min-width:220px;position:relative;}
.pr-search input{width:100%;background:#0c0b0a;border:1px solid var(--line-soft);border-radius:999px;padding:13px 18px 13px 44px;color:var(--white);font-size:14px;font-family:var(--sans);}
.pr-search input:focus{outline:none;border-color:var(--gold);}
.pr-search svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--gold-soft);}
.pr-sort{background:rgba(203,161,79,0.06);border:1px solid var(--line);color:var(--gold-bright);font-size:12.5px;font-weight:600;padding:13px 18px;border-radius:999px;cursor:pointer;white-space:nowrap;transition:background .2s;}
.pr-sort:hover{background:rgba(203,161,79,0.12);}
.pr-sort.active{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1407;border-color:transparent;}
.pr-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px;}
.pr-filter{background:transparent;border:1px solid var(--line-soft);color:var(--muted);font-size:12px;font-weight:500;padding:8px 15px;border-radius:999px;cursor:pointer;transition:all .18s;}
.pr-filter:hover{border-color:var(--gold);color:var(--gold-bright);}
.pr-filter.active{background:rgba(203,161,79,0.14);border-color:var(--gold);color:var(--gold-bright);font-weight:600;}
.pr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:14px;}
.outlet{position:relative;background:linear-gradient(165deg,var(--panel-hi),var(--panel));border:1px solid var(--line-soft);border-radius:9px;padding:18px 18px 16px;cursor:pointer;transition:transform .18s,border-color .18s,box-shadow .18s;will-change:transform;}
.outlet:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 22px 44px -28px rgba(0,0,0,0.9);}
.outlet.selected{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold),0 22px 44px -28px rgba(203,161,79,0.4);background:linear-gradient(165deg,rgba(203,161,79,0.12),var(--panel));}
.outlet-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;}
.outlet-name{font-size:15.5px;font-weight:700;color:#fff;text-decoration:none;line-height:1.25;}
.outlet-name:hover{color:var(--gold-bright);text-decoration:underline;}
.outlet-check{flex:none;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:#1a1407;font-size:13px;font-weight:800;transition:all .18s;}
.outlet.selected .outlet-check{background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-color:transparent;}
.outlet-genre{font-size:11.5px;color:var(--gold-soft);margin-top:5px;letter-spacing:0.3px;}
.outlet-price{font-family:var(--serif);font-size:31px;font-weight:700;color:var(--gold-bright);margin:12px 0 2px;line-height:1;}
.outlet-price small{font-size:11px;color:var(--muted);font-family:var(--sans);font-weight:400;letter-spacing:0.5px;}
.outlet-stats{display:flex;gap:14px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line-soft);}
.outlet-stat{display:flex;flex-direction:column;gap:2px;}
.outlet-stat .k{font-size:9px;letter-spacing:0.8px;text-transform:uppercase;color:var(--muted);}
.outlet-stat .v{font-size:13px;font-weight:600;color:var(--text);}
.pr-loadmore{display:block;margin:26px auto 0;background:transparent;border:1px solid var(--line);color:var(--gold-bright);font-size:13px;font-weight:600;padding:14px 32px;border-radius:999px;cursor:pointer;transition:background .2s;}
.pr-loadmore:hover{background:rgba(203,161,79,0.08);}
.pr-empty{text-align:center;padding:50px 20px;color:var(--muted);}
.pr-empty h4{font-family:var(--serif);font-size:22px;color:var(--white);margin-bottom:6px;}
.pr-sticky{position:fixed;left:0;right:0;bottom:0;z-index:30;transform:translateY(120%);visibility:hidden;pointer-events:none;transition:transform .3s cubic-bezier(.16,1,.3,1),visibility 0s linear .3s;}
.pr-sticky.visible{transform:translateY(0);visibility:visible;pointer-events:auto;transition:transform .3s cubic-bezier(.16,1,.3,1);}
.pr-sticky-inner{max-width:1180px;background:linear-gradient(180deg,var(--panel-hi),var(--ink));border:1px solid var(--line);border-bottom:none;border-radius:12px 12px 0 0;box-shadow:0 -20px 50px -20px rgba(0,0,0,0.9);padding:16px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 28px;}
.pr-sticky-left{display:flex;align-items:center;gap:14px;min-width:0;}
.pr-sel-count{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--gold-bright);line-height:1;}
.pr-sticky-left .lbl{font-size:12px;color:var(--muted);}
.pr-sticky-left .names{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:40vw;}
.pr-cont{flex:none;background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#1a1407;font-weight:700;font-size:13px;letter-spacing:0.4px;border:none;border-radius:999px;padding:13px 26px;cursor:pointer;transition:transform .15s,filter .2s;}
.pr-cont:hover{transform:translateY(-1px);filter:brightness(1.06);}
.pr-est{font-size:11px;color:var(--gold-soft);margin-top:3px;}

footer{position:relative;z-index:1;border-top:1px solid var(--line-soft);margin-top:80px;padding:28px 0 60px;}
footer .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}
footer p{font-size:11.5px;color:#736e64;letter-spacing:0.4px;}
footer .dots{display:flex;gap:8px;}
footer .dots i{width:5px;height:5px;background:var(--line);transform:rotate(45deg);}

/* ───────────────────────────────────────────────
   RECONCILIATION — classes Dev introduced this round
   (semantic names replacing former inline styles &
   fragile descendant selectors). Theme-matched values.
   ─────────────────────────────────────────────── */

/* Structural wrappers — keep normal block flow, don't break layout.
   (.svc-groups styled in the SERVICES PAGE block above.) */
.pr-form{display:block;}

/* Explicit SVG icon classes (robust replacements for descendant selectors). */
.svc-badge-ico{width:34px;height:34px;}                  /* matches .svc-badge svg (Round-2 badge is 64px) */
.form-badge-ico{width:30px;height:30px;}                 /* matches .form-aside .form-badge svg */
.seal-ico{color:var(--gold-bright);}                     /* seal check uses width/height attrs */
.pr-search-ico{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--gold-soft);} /* matches .pr-search svg */

/* Assurance blocks — Dev replaced reliance on .assure div with .assure-item.
   (Typography set in the SERVICES PAGE block above so both selectors match.) */

/* Thumbnail × remove button — formerly styled via .thumb button. */
.thumb-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;border:none;background:rgba(0,0,0,0.75);color:#fff;cursor:pointer;font-size:12px;line-height:1;}

/* File <input> inside .upload — must be hidden (label is the visible target). */
.upload-input{display:none;}

/* Fine-print helper under forms (co-exists with .gate-note). */
.form-note{margin-top:14px;font-size:11.5px;color:#736e64;text-align:center;}

/* ───────────────────────────────────────────────
   CLIENT-PORTAL FAQ — native <details>/<summary> accordion
   Full-width, compact, skimmable block ABOVE the form card on
   both the service form screen and the PR screen. Each item is a
   <details> row; the <summary> is the gold-bright question with a
   custom ▸ marker that rotates to ▾ when [open]. Matches the
   premium gold/black/white card language.
   ─────────────────────────────────────────────── */
.svc-faq{
  display:block;width:100%;
  max-width:var(--grid-max);margin:0 auto 26px;
}
.svc-faq:empty{display:none;}   /* hidden until JS fills it */
.svc-faq-head{
  font-size:12px;letter-spacing:3.4px;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin-bottom:14px;
}
.svc-faq-list{display:flex;flex-direction:column;gap:10px;}

/* Each row: a collapsed panel that expands in place. */
.svc-faq-item{
  background:var(--panel);
  border:1px solid var(--line-soft);border-radius:10px;
  padding:0 18px;overflow:hidden;
  transition:border-color .2s,background .2s;
}
.svc-faq-item[open]{border-color:var(--line);background:var(--panel-2);}
.svc-faq-item:hover{border-color:var(--line);}

/* The <summary> — gold-bright question. Hide the default disclosure
   triangle and supply our own ▸ that rotates to ▾ when [open]. */
.svc-faq-q{
  list-style:none;cursor:pointer;
  display:flex;align-items:flex-start;gap:12px;
  padding:16px 0;
  font-family:var(--sans);font-size:15px;font-weight:600;
  line-height:1.45;color:var(--gold-bright);
  transition:color .18s;
}
.svc-faq-q:hover{color:var(--white);}
summary.svc-faq-q{list-style:none;}
.svc-faq-q::-webkit-details-marker{display:none;}
.svc-faq-q::marker{content:'';}
/* Custom rotating marker (▸ → ▾). */
.svc-faq-q::before{
  content:'▸';flex:none;
  color:var(--gold);font-size:13px;line-height:1.6;
  transition:transform .22s ease,color .18s;
}
.svc-faq-item[open] .svc-faq-q::before{
  transform:rotate(90deg);color:var(--gold-bright);
}

/* The answer — muted, comfortable line-height, indented to align
   under the question text (past the marker). */
.svc-faq-a{
  color:var(--muted);font-size:14px;font-weight:300;line-height:1.66;
  padding:0 0 18px 24px;
}

/* Compact H1 size override — smaller than the default .display.
   Used by the partner dashboard's login + greeting headings. */
.display-signin{font-size:clamp(34px,5vw,58px);}

/* Layout modifiers / spacing. */
.success-actions{margin-top:24px;}
.back-edit{margin-top:18px;}
.form-shell-pr{margin-top:4px;}
.pr-estimate-val{color:var(--gold-bright);font-weight:700;}

/* ───────────────────────────────────────────────
   ACCESSIBILITY — keyboard focus
   .svc cards have tabindex="0"; give them + every
   interactive element a clear, on-brand focus ring.
   ─────────────────────────────────────────────── */
:where(a,button,input,select,textarea,summary,.svc,.outlet,[tabindex="0"]):focus-visible{
  outline:2px solid var(--gold-bright);
  outline-offset:3px;
  border-radius:6px;
}
/* Keep the FAQ summary's focus ring tucked just inside its rounded row. */
.svc-faq-q:focus-visible{outline-offset:0;border-radius:10px;}
/* Programmatic focus targets (the screen sections get tabindex="-1" so show() can move focus
   to them for screen readers) must NOT draw a visible ring — otherwise a big gold box flashes
   around the whole screen on load until the user clicks. Keep the ring only on real tab stops. */
.screen:focus,.screen:focus-visible,[tabindex="-1"]:focus,[tabindex="-1"]:focus-visible{outline:none;box-shadow:none;}
.svc:focus-visible,.outlet:focus-visible{
  outline:2px solid var(--gold-bright);
  outline-offset:3px;
  border-color:var(--gold);
}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible,
.pr-search input:focus-visible{outline:none;}

/* ───────────────────────────────────────────────
   UTILITY HELPERS
   Dev (Agent 2) may convert inline style="" into these
   semantic classes this round — pre-styling them here.
   ─────────────────────────────────────────────── */
.is-hidden{display:none!important;}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
/* Standard accessible off-screen pattern (screen-reader-only labels). */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;}
.text-center{text-align:center;}
.nowrap{white-space:nowrap;}
.accent-text{color:var(--gold-bright);}
.full-bleed{grid-column:1/-1;}        /* e.g. .pr-empty spanning the grid */
.mt-0{margin-top:0;}
.mt-sm{margin-top:8px;}
.mt-md{margin-top:18px;}
.mt-lg{margin-top:24px;}

/* ───────────────────────────────────────────────
   RESPONSIVE — large desktop
   ─────────────────────────────────────────────── */
@media(min-width:1240px){
  /* Wider gutters + slightly larger min so two roomy cards center the row;
     fit + capped max keeps a lone card from stretching full-width. */
  .svc-grid{grid-template-columns:repeat(auto-fit,minmax(360px,440px));gap:26px;justify-content:center;}
}

/* ── Tablet (<=860px) ── */
@media(max-width:860px){
  .assure{grid-template-columns:1fr;gap:22px;max-width:480px;}
  .form-shell{grid-template-columns:1fr;gap:26px;}
  .pr-sticky-left .names{display:none;}
  /* Tablet: let cards fill the column (1fr) and reduce the section heading. */
  .svc-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
  .cat-label{font-size:clamp(26px,5vw,34px);margin-bottom:22px;}
  .pr-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));}
}

/* ── Mobile (<=560px) ── */
@media(max-width:560px){
  .wrap{padding:0 18px;}
  .topbar{padding:18px 0 12px;}
  /* Phone: single full-width column, centered automatically by the cap. */
  .svc-grid{grid-template-columns:1fr;gap:18px;}
  .svc{padding:28px 24px 24px;}
  .svc h4{font-size:27px;}
  .svc p{font-size:15.5px;}
  .svc-foot{flex-wrap:wrap;}
  /* Keep the section headings big & legible, just not oversized, on phones. */
  .cat{margin-top:46px;}
  .cat-label{font-size:27px;margin-bottom:18px;gap:14px;}
  .cat-label::before{width:24px;}
  .assure{margin-top:56px;padding-top:36px;}
  .form-card{padding:26px 20px;}
  /* PR grid: 1 column on phones so cards & prices stay legible */
  .pr-grid{grid-template-columns:1fr;}
  .pr-toolbar{flex-direction:column;align-items:stretch;}
  .pr-sort{width:100%;}
  .outlet-stats{gap:10px;}
  /* Sticky bar: stack count + CTA so it never overflows a phone */
  .pr-sticky-inner{margin:0 12px;padding:13px 16px;gap:12px;}
  .pr-sticky-left{gap:11px;}
  .pr-sel-count{font-size:24px;}
  .pr-cont{padding:12px 18px;font-size:12.5px;}
  .pr-intro{flex-direction:column;align-items:flex-start;}
  /* FAQ: tighten padding + type so it stays compact on phones. */
  .svc-faq{margin-bottom:22px;}
  .svc-faq-item{padding:0 14px;}
  .svc-faq-q{font-size:14.5px;padding:14px 0;}
  .svc-faq-a{font-size:13.5px;padding-bottom:15px;padding-left:22px;}
}

/* very small phones — keep the sticky CTA readable */
@media(max-width:380px){
  .pr-cont{padding:11px 14px;}
  .pr-sel-count{font-size:21px;}
}

/* ───────────────────────────────────────────────
   REDUCED MOTION — disable transforms/animations
   ─────────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
  html{scroll-behavior:auto;}
  .screen{animation:none!important;}
  .svc:hover,.outlet:hover,.btn:hover,.pr-cont:hover{transform:none!important;}
  .pr-sticky{transition:none!important;}
  /* FAQ marker still flips state, just without the animated rotation. */
  .svc-faq-q::before,.svc-faq-item,.svc-faq-q{transition:none!important;}
}

/* ── Mobile polish: never force a zoom-out, premium tactile button feedback ── */
html,body{max-width:100%;overflow-x:hidden;}
img,svg,video,code,pre,input,textarea,select{max-width:100%;box-sizing:border-box;}
.btn,.svc,.svc-cta,button,.pr-sel-count,[role="button"]{
  -webkit-tap-highlight-color:transparent; touch-action:manipulation;
  transition:transform .08s ease, filter .15s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.btn:active,.svc:active,.svc-cta:active,button:active,[role="button"]:active{ transform:scale(.97); }
@media(hover:none){
  .btn,.svc-cta,button{min-height:46px;}
}

/* ── Smooth mobile scrolling: GPU-layer the fixed decorative backgrounds so they don't repaint on
   every scroll frame (the #1 cause of scroll stutter on iOS), and contain overscroll bounce. ── */
body::before,body::after{will-change:transform;transform:translateZ(0);backface-visibility:hidden;}
.pr-sticky{will-change:transform;}
html{scroll-behavior:auto;}
@media(max-width:900px){
  html,body{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;}
}

/* ── iOS: a field under 16px auto-zooms the page on focus (then the user's stuck zoomed-in).
   Force 16px on small screens for every field across both portals. ── */
@media(max-width:900px){ input,select,textarea{font-size:16px !important;} }

/* ── Premium mobile spacing: let the "Our Services / How can we help" landing breathe ── */
@media(max-width:600px){
  .svc-head-row{padding-top:6px;margin-bottom:42px;}
  .svc-head-row .display{margin-top:22px;}
  .svc-head-row .lede{margin-top:22px;line-height:1.72;}
  .svc-grid{gap:22px;}
  .assure{margin-top:66px;padding-top:44px;gap:28px;}
}
