/* ============================================================
   THINGLET MARKETING — shared design system
   Brand: full-service marketing, Coachella Valley
   Signature: broadcast signal (rings + waveform) in azure
   ============================================================ */

:root{
  /* palette */
  --azure:#0A9DCC;          /* brand signal blue — fills, accents, big text */
  --azure-deep:#0B7491;     /* darker azure for text/links on light (AA) */
  --azure-soft:#E6F4F9;     /* tints, card surfaces */
  --ink:#3d3d3d;            /* body text (mandated charcoal) */
  --ink-strong:#232629;     /* headings */
  --night:#0B2530;          /* deep teal-navy dark sections */
  --night-2:#0f3140;        /* lighter dark panel */
  --coral:#F0573B;          /* energy accent — CTAs, key highlights (sparing) */
  --coral-deep:#d8462c;
  --paper:#F4F8FA;          /* cool light page background */
  --white:#ffffff;
  --line:rgba(11,37,48,.12);
  --line-2:rgba(11,37,48,.20);
  --line-dark:rgba(255,255,255,.14);
  --line-dark-2:rgba(255,255,255,.26);

  /* type */
  --display:'Bricolage Grotesque',Georgia,serif;
  --body:'Albert Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;

  --maxw:1180px;
  --radius:16px;
  --shadow:0 18px 50px rgba(11,37,48,.10);
  --shadow-lg:0 30px 80px rgba(11,37,48,.16);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative}

/* ---------- type scale ---------- */
h1,h2,h3,h4{font-family:var(--display);color:var(--ink-strong);line-height:1.05;letter-spacing:-.02em;font-weight:700}
.h-xl{font-size:clamp(2.6rem,6vw,4.5rem);font-weight:800;letter-spacing:-.03em}
.h-lg{font-size:clamp(2rem,4.6vw,3.2rem);font-weight:700}
.h-md{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700}
.lede{font-size:clamp(1.08rem,1.6vw,1.28rem);color:var(--ink);max-width:60ch}
.muted{color:#5b6b71}

.eyebrow{
  font-family:var(--mono);font-size:.74rem;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--azure-deep);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow .sig-dot{
  width:8px;height:8px;border-radius:50%;background:var(--azure);
  box-shadow:0 0 0 0 rgba(10,157,204,.5);
}
@media (prefers-reduced-motion:no-preference){
  .eyebrow .sig-dot{animation:ping 2.4s ease-out infinite}
}
@keyframes ping{
  0%{box-shadow:0 0 0 0 rgba(10,157,204,.5)}
  70%{box-shadow:0 0 0 10px rgba(10,157,204,0)}
  100%{box-shadow:0 0 0 0 rgba(10,157,204,0)}
}
.on-dark .eyebrow{color:#7fd4ec}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--body);font-weight:600;font-size:1rem;letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:.6em;justify-content:center;
  padding:15px 26px;border-radius:12px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease;
}
.btn:focus-visible{outline:3px solid var(--azure);outline-offset:3px}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 10px 28px rgba(240,87,59,.32)}
.btn-primary:hover{background:var(--coral-deep);transform:translateY(-2px);box-shadow:0 14px 34px rgba(240,87,59,.42)}
.btn-azure{background:var(--azure);color:#04212b;font-weight:700;box-shadow:0 10px 28px rgba(10,157,204,.30)}
.btn-azure:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(10,157,204,.42)}
.btn-ghost{background:transparent;border-color:var(--line-2);color:var(--ink-strong)}
.btn-ghost:hover{border-color:var(--azure);color:var(--azure-deep);background:var(--azure-soft)}
.on-dark .btn-ghost{border-color:var(--line-dark-2);color:#eaf6fa}
.on-dark .btn-ghost:hover{border-color:#7fd4ec;color:#fff;background:rgba(255,255,255,.06)}
.btn-block{width:100%}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:60;background:rgba(244,248,250,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{flex:none}
.brand .name{font-family:var(--display);font-weight:800;font-size:1.18rem;letter-spacing:.01em;color:var(--ink-strong);line-height:1;text-transform:uppercase}
.brand .name small{display:block;font-family:var(--mono);font-weight:500;font-size:.55rem;letter-spacing:.26em;color:var(--azure);text-transform:uppercase;margin-top:5px}
.on-dark .brand .name,.foot .brand .name{color:#fff}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.96rem;font-weight:500;color:var(--ink);transition:color .18s}
.nav-links a:hover{color:var(--azure-deep)}
.nav-links a.active{color:var(--azure-deep);font-weight:600}
.nav-links .btn{padding:11px 20px;font-size:.92rem}
.burger{display:none;flex-direction:column;gap:5px;padding:10px;cursor:pointer;background:none;border:0}
.burger span{width:24px;height:2px;background:var(--ink-strong);border-radius:2px;transition:.25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:900px){
  .nav-links{position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--white);border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    max-height:0;overflow:hidden;transition:max-height .3s ease}
  .nav-links.open{max-height:460px}
  .nav-links a{padding:16px 24px;border-top:1px solid var(--line)}
  .nav-links .btn{margin:14px 24px}
  .burger{display:flex}
}

/* ---------- section shell ---------- */
.section{padding:88px 0}
.section.tight{padding:60px 0}
.on-dark{background:var(--night);color:#cfe3ea}
.on-dark h1,.on-dark h2,.on-dark h3,.on-dark h4{color:#fff}
.on-dark .lede{color:#bcd3dc}
.on-dark .muted{color:#8fb0bb}
.sec-head{max-width:680px;margin:0 0 48px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{margin:14px 0 16px}
.divider-wave{height:2px;border:0;background:linear-gradient(90deg,transparent,var(--azure),transparent);opacity:.5;margin:0}

/* ---------- HERO + signal signature ---------- */
.hero{position:relative;overflow:hidden;background:radial-gradient(120% 120% at 80% -10%,#11465a 0%,var(--night) 55%)}
.hero .wrap{padding-top:96px;padding-bottom:104px}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
@media(max-width:940px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero h1{margin:18px 0 22px;color:#fff}
.hero h1 .amp{color:var(--azure);position:relative;white-space:nowrap}
.hero-sub{color:#bcd3dc;font-size:clamp(1.05rem,1.6vw,1.24rem);max-width:54ch;margin-bottom:30px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero-channels{display:flex;flex-wrap:wrap;gap:10px 10px}
.hero-channels .chan{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  padding:7px 13px;border-radius:100px;border:1px solid var(--line-dark-2);color:#bcd3dc;
  text-decoration:none;cursor:pointer;transition:border-color .2s,color .2s,background .2s;
}
a.chan:hover{border-color:var(--azure);color:#fff;background:rgba(10,157,204,.18)}
a.chan:focus-visible{outline:3px solid var(--azure);outline-offset:2px}

/* signal visual (right of hero) */
.signal{position:relative;aspect-ratio:1/1;width:100%;max-width:420px;margin:0 auto;display:grid;place-items:center}
.signal .rings{position:absolute;inset:0;display:grid;place-items:center}
.signal .ring{position:absolute;border:1.5px solid rgba(10,157,204,.5);border-radius:50%;width:24%;height:24%}
.signal .ring.r2{width:48%;height:48%;opacity:.55}
.signal .ring.r3{width:72%;height:72%;opacity:.35}
.signal .ring.r4{width:96%;height:96%;opacity:.18}
@media (prefers-reduced-motion:no-preference){
  .signal .ring{animation:wave 4s ease-out infinite}
  .signal .ring.r2{animation-delay:.6s}
  .signal .ring.r3{animation-delay:1.2s}
  .signal .ring.r4{animation-delay:1.8s}
}
@keyframes wave{
  0%{transform:scale(.6);opacity:.7;border-color:rgba(10,157,204,.7)}
  100%{transform:scale(1.25);opacity:0;border-color:rgba(10,157,204,0)}
}
.signal .core{
  position:relative;z-index:2;width:78px;height:78px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 35% 30%,#34c6ee,var(--azure));
  box-shadow:0 0 0 8px rgba(10,157,204,.16),0 12px 40px rgba(10,157,204,.5);
}
.signal .core svg{width:38px;height:38px}
.signal .waveline{position:absolute;left:0;right:0;bottom:14%;width:100%;height:60px;z-index:1;opacity:.9}
.signal .waveline path{fill:none;stroke:var(--azure);stroke-width:2.5;stroke-linecap:round}
@media (prefers-reduced-motion:no-preference){
  .signal .waveline path{stroke-dasharray:6 10;animation:flow 1.6s linear infinite}
}
@keyframes flow{to{stroke-dashoffset:-32}}

/* ---------- channel marquee ---------- */
.marquee{background:var(--night-2);border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);overflow:hidden;padding:18px 0}
.marquee-track{display:flex;gap:54px;white-space:nowrap;width:max-content}
@media (prefers-reduced-motion:no-preference){.marquee-track{animation:marq 26s linear infinite}}
@keyframes marq{to{transform:translateX(-50%)}}
.marquee-track span{font-family:var(--display);font-weight:700;font-size:1.25rem;color:#7fd4ec;display:inline-flex;align-items:center;gap:54px}
.marquee-track span::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral)}

/* ---------- service cards (home) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
.svc{
  display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 28px;transition:transform .22s ease,box-shadow .22s ease,border-color .22s;
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.svc::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--azure);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc:hover::before{transform:scaleX(1)}
.svc .ic{width:54px;height:54px;border-radius:13px;background:var(--azure-soft);display:grid;place-items:center;margin-bottom:18px;color:var(--azure-deep)}
.svc .ic svg{width:28px;height:28px}
.svc h3{font-size:1.4rem;margin-bottom:8px}
.svc p{font-size:.98rem;color:#5b6b71;flex:1;margin-bottom:18px}
.svc .go{font-family:var(--mono);font-size:.82rem;letter-spacing:.04em;color:var(--azure-deep);font-weight:500;display:inline-flex;align-items:center;gap:7px}
.svc:hover .go{gap:12px}
.svc .price-from{font-family:var(--mono);font-size:.8rem;color:var(--coral);font-weight:500;margin-bottom:14px}

/* ---------- value / why grid ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.why-grid{grid-template-columns:1fr}}
.why{padding:26px 22px;border-radius:14px;background:var(--white);border:1px solid var(--line)}
.why .n{font-family:var(--mono);font-size:.78rem;letter-spacing:.1em;color:var(--azure-deep);margin-bottom:12px}
.why h4{font-size:1.12rem;margin-bottom:7px}
.why p{font-size:.92rem;color:#5b6b71}

/* ---------- pricing tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
@media(max-width:960px){.tiers{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
.tier{
  position:relative;display:flex;flex-direction:column;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;box-shadow:var(--shadow);
  transition:transform .22s,box-shadow .22s,border-color .22s;
}
.tier:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.tier.feat{border-color:var(--azure);box-shadow:0 0 0 1px var(--azure),var(--shadow-lg)}
.tier .pop{position:absolute;top:-13px;left:28px;font-family:var(--mono);font-size:.66rem;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;background:var(--coral);color:#fff;padding:6px 13px;border-radius:100px}
.tier .tag{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--azure-deep);margin-bottom:8px}
.tier h3{font-size:1.5rem;margin-bottom:4px}
.tier .blurb{font-size:.9rem;color:#5b6b71;margin-bottom:20px;min-height:42px}
.tier .price{display:flex;align-items:baseline;gap:5px;margin-bottom:4px}
.tier .price .cur{font-size:1.3rem;font-weight:700;color:#5b6b71;font-family:var(--display)}
.tier .price .amt{font-family:var(--display);font-size:3rem;font-weight:800;letter-spacing:-.03em;color:var(--ink-strong)}
.tier .price .per{font-family:var(--mono);font-size:.78rem;color:#5b6b71}
.tier .submo{font-family:var(--mono);font-size:.8rem;color:var(--azure-deep);margin-bottom:22px}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:26px;flex:1}
.tier li{font-size:.94rem;color:var(--ink);display:flex;gap:11px;align-items:flex-start}
.tier li svg{flex:none;width:18px;height:18px;margin-top:3px;color:var(--azure)}
.tier li b{color:var(--ink-strong);font-weight:600}
.tier.feat .price .amt{color:var(--azure-deep)}

.note-card{
  margin-top:28px;border:1px dashed var(--line-2);border-radius:14px;padding:22px 24px;
  background:var(--white);font-size:.96rem;color:#5b6b71;text-align:center;
}
.note-card b{color:var(--ink-strong)}
.note-card a{color:var(--azure-deep);font-weight:600;text-decoration:underline;text-underline-offset:2px}

/* ---------- traditional channels list ---------- */
.chan-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:760px){.chan-grid{grid-template-columns:1fr}}
.chan-card{display:flex;gap:18px;align-items:flex-start;background:var(--white);border:1px solid var(--line);border-radius:14px;padding:26px 24px;transition:border-color .2s,transform .2s}
.chan-card:hover{border-color:var(--azure);transform:translateY(-3px)}
.chan-card .ic{flex:none;width:50px;height:50px;border-radius:12px;background:var(--azure-soft);color:var(--azure-deep);display:grid;place-items:center}
.chan-card .ic svg{width:26px;height:26px}
.chan-card h4{font-size:1.2rem;margin-bottom:6px}
.chan-card p{font-size:.94rem;color:#5b6b71}

.banner-incl{
  display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:center;text-align:center;
  background:var(--azure-soft);border:1px solid rgba(10,157,204,.25);border-radius:var(--radius);
  padding:28px 30px;margin-top:34px;
}
.banner-incl .pill{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;background:var(--azure);color:#04212b;font-weight:700;padding:7px 14px;border-radius:100px}
.banner-incl p{color:var(--ink-strong);font-size:1.02rem;max-width:60ch}

/* ---------- cta band ---------- */
.cta-band{background:var(--coral);color:#fff;position:relative;overflow:hidden}
.cta-band .wrap{padding:64px 24px;text-align:center;position:relative;z-index:2}
.cta-band h2{color:#fff;margin-bottom:14px}
.cta-band p{color:#ffe4dd;max-width:54ch;margin:0 auto 26px;font-size:1.08rem}
.cta-band .btn-azure{background:#fff;color:var(--coral-deep)}
.cta-band .btn-azure:hover{background:#04212b;color:#fff}

/* ---------- forms ---------- */
.form-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:34px 32px;max-width:760px;margin:0 auto}
@media(max-width:560px){.form-card{padding:26px 20px}}
.form-head{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.form-head .ic{width:46px;height:46px;border-radius:12px;background:var(--azure-soft);color:var(--azure-deep);display:grid;place-items:center;flex:none}
.form-head h3{font-size:1.4rem}
.form-sub{font-family:var(--mono);font-size:.78rem;color:#5b6b71;margin-bottom:24px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.fgrid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field.full{grid-column:1/-1}
.field label{font-size:.9rem;font-weight:600;color:var(--ink-strong)}
.field label .req{color:var(--coral);margin-left:2px}
.field .hint{font-size:.78rem;color:#5b6b71;font-weight:400}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:1rem;color:var(--ink-strong);background:var(--paper);
  border:1.5px solid var(--line-2);border-radius:11px;padding:13px 15px;width:100%;transition:border-color .18s,box-shadow .18s;
}
.field textarea{min-height:120px;resize:vertical;line-height:1.55}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 3px rgba(10,157,204,.16)}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:var(--coral);box-shadow:0 0 0 3px rgba(240,87,59,.16)}
.field .fs-err{color:var(--coral-deep);font-size:.78rem;font-family:var(--mono);min-height:1em}
.plan-pick{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px}
.plan-pick label{font-size:.9rem;padding:11px 16px;border:1.5px solid var(--line-2);border-radius:11px;cursor:pointer;color:var(--ink);transition:.16s;display:inline-flex;gap:8px;align-items:center}
.plan-pick input{accent-color:var(--azure);width:16px;height:16px}
.plan-pick label:has(input:checked){border-color:var(--azure);background:var(--azure-soft);color:var(--azure-deep);font-weight:600}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.submit-row{margin-top:8px}
.consent{font-size:.8rem;color:#5b6b71;margin-top:14px;text-align:center}
.fs-success{display:none;border:1px solid var(--azure);background:var(--azure-soft);color:var(--azure-deep);
  border-radius:12px;padding:18px;font-size:.96rem;margin-bottom:20px;font-weight:500}
.fs-form-error{display:none;border:1px solid var(--coral);background:#fdece8;color:var(--coral-deep);
  border-radius:12px;padding:18px;font-size:.96rem;margin-bottom:20px;font-weight:500}

/* ---------- contact info blocks ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:32px}}
.info-list{display:flex;flex-direction:column;gap:22px}
.info-item{display:flex;gap:16px;align-items:flex-start}
.info-item .ic{flex:none;width:46px;height:46px;border-radius:12px;background:var(--azure-soft);color:var(--azure-deep);display:grid;place-items:center}
.info-item .ic svg{width:22px;height:22px}
.info-item h4{font-size:1.02rem;margin-bottom:3px}
.info-item a,.info-item p{font-size:.98rem;color:#5b6b71}
.info-item a:hover{color:var(--azure-deep)}
.map-embed{margin-top:8px;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.map-embed iframe{width:100%;height:300px;border:0;display:block}

/* ---------- page header strip ---------- */
.page-head{background:var(--night);color:#fff;position:relative;overflow:hidden}
.page-head::after{content:"";position:absolute;right:-80px;top:50%;transform:translateY(-50%);
  width:420px;height:420px;border-radius:50%;border:1.5px solid rgba(10,157,204,.18);
  box-shadow:0 0 0 60px rgba(10,157,204,.05),0 0 0 130px rgba(10,157,204,.03)}
.page-head .wrap{padding:72px 24px;position:relative;z-index:2}
.page-head h1{color:#fff;margin:14px 0 16px;max-width:18ch}
.page-head p{color:#bcd3dc;max-width:60ch;font-size:1.12rem}

/* ---------- footer ---------- */
.foot{background:var(--night);color:#9fbcc6;padding:60px 0 30px;border-top:3px solid var(--azure)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:36px;margin-bottom:40px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot .brand .name{color:#fff}
.foot p{font-size:.92rem;color:#9fbcc6;max-width:34ch;margin-top:14px}
.foot h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#7fd4ec;margin-bottom:16px}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot ul a,.foot address a{font-size:.92rem;color:#9fbcc6;transition:color .18s;font-style:normal}
.foot ul a:hover,.foot address a:hover{color:#fff}
.foot address{font-style:normal;font-size:.92rem;line-height:1.7;color:#9fbcc6}
.foot-bot{border-top:1px solid var(--line-dark);padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:.74rem;color:#6f939e}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto!important}
}

/* ---------- a11y ---------- */
.skip{position:absolute;left:-9999px;top:0;z-index:999;background:var(--azure);color:#04212b;padding:12px 18px;font-weight:700;border-radius:0 0 8px 0}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--azure);outline-offset:2px;border-radius:4px}

/* ============================================================
   WEBSITE PACKAGE BRIEFS — fieldsets, chips, modals
   (geekworks structure, re-themed to Thinglet azure)
   ============================================================ */
.brief-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:34px 32px;max-width:760px;margin:0 auto}
@media(max-width:560px){.brief-card{padding:26px 20px}}
.brief-card .bc-head{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.brief-card .bc-head .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:1.35rem;background:var(--azure-soft)}
.brief-card h3{font-size:1.4rem;font-weight:800;color:var(--ink-strong)}
.brief-card .bc-sub{font-family:var(--mono);font-size:.76rem;color:#5b6b71;margin-bottom:26px}
.fs{border:none;margin:0 0 26px;padding:0}
.fs legend{font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--secol,var(--azure-deep));font-weight:700;display:flex;align-items:center;gap:9px;margin-bottom:16px;width:100%}
.fs legend .num{width:22px;height:22px;border-radius:6px;background:var(--secol,var(--azure));color:#fff;display:grid;place-items:center;font-size:.7rem;font-weight:700;flex:none}
.color-row{display:flex;gap:16px;flex-wrap:wrap}
.color-row .field{flex:1;min-width:150px;margin:0}
.field input[type=color]{height:46px;padding:5px;cursor:pointer}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chips label{font-size:.86rem;padding:9px 14px;border:1.5px solid var(--line-2);border-radius:10px;cursor:pointer;color:var(--ink);transition:.16s;user-select:none}
.chips input{display:none}
.chips label:has(input:checked){border-color:var(--secol,var(--azure));color:var(--secol,var(--azure-deep));background:var(--azure-soft);font-weight:600}
.btn-submit{width:100%;justify-content:center;background:var(--secol,var(--azure));color:#fff;font-size:.95rem;padding:16px;font-weight:700}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 12px 34px rgba(10,157,204,.34)}
.btn-submit:disabled{opacity:.55;cursor:not-allowed;transform:none}

/* per-package accent driving --secol */
#form-fun{--secol:var(--azure-deep)}
#form-business{--secol:#0A9DCC}
#form-medium{--secol:var(--coral-deep)}

/* MODALS */
.modal-overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(8,28,37,.62);backdrop-filter:blur(4px);padding:30px 16px;overflow-y:auto}
.modal-overlay.open{display:flex;align-items:flex-start;justify-content:center;animation:ovIn .25s ease}
@keyframes ovIn{from{opacity:0}to{opacity:1}}
.modal-dialog{position:relative;width:100%;max-width:780px;margin:auto;animation:dlgIn .28s cubic-bezier(.2,.8,.2,1)}
@keyframes dlgIn{from{opacity:0;transform:translateY(24px) scale(.985)}to{opacity:1;transform:none}}
.modal-dialog .brief-card{max-width:none;margin:0}
.modal-close{position:absolute;top:-6px;right:-6px;z-index:5;width:42px;height:42px;border-radius:50%;border:1px solid var(--line-2);background:var(--white);color:var(--ink-strong);font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);transition:.2s}
.modal-close:hover{border-color:var(--coral);color:var(--coral-deep);transform:rotate(90deg)}
@media(max-width:560px){.modal-close{top:4px;right:4px}}
body.modal-open{overflow:hidden}

/* steps (build process on websites page) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:880px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.steps{grid-template-columns:1fr}}
.step{border:1px solid var(--line);border-radius:14px;padding:24px 20px;background:var(--white);box-shadow:var(--shadow)}
.step .n{font-family:var(--mono);font-size:2.1rem;font-weight:700;color:var(--azure);line-height:1;margin-bottom:12px}
.step h4{font-size:1.05rem;font-weight:700;margin-bottom:8px;color:var(--ink-strong)}
.step p{font-size:.9rem;color:#5b6b71}

/* custom-note */
.custom-note{margin-top:28px;border:1px dashed var(--line-2);border-radius:14px;padding:22px 24px;background:var(--azure-soft);font-size:.96rem;color:var(--ink);max-width:860px}
.custom-note b{color:var(--azure-deep)}

/* FAQ accordion */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq{border:1px solid var(--line);border-radius:13px;background:var(--white);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:600;color:var(--ink-strong);display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{font-family:var(--mono);color:var(--azure);font-size:1.3rem;transition:.2s;flex:none}
.faq[open] summary .pm{transform:rotate(45deg)}
.faq .ans{padding:0 22px 20px;color:#5b6b71;font-size:.94rem;line-height:1.6}

/* 6-up service grid */
.svc-grid.six{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.svc-grid.six{grid-template-columns:1fr 1fr;max-width:none}}
@media(max-width:520px){.svc-grid.six{grid-template-columns:1fr;max-width:480px}}
