:root{--black:#000;--white:#fff;--off:#f7f7f5;--dim:#666;--border:#e0e0e0;--accent:#c8ff00;--font:'Inter',system-ui,sans-serif;--ease:.4s cubic-bezier(.25,.46,.45,.94)}
[hidden]{display:none!important}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--white);color:var(--black);overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
button{font-family:var(--font);cursor:pointer;border:none;background:none}
ul{list-style:none}

/* CURSOR */
#cursor-dot,#cursor-ring{position:fixed;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%)}
#cursor-dot{width:6px;height:6px;background:var(--white);mix-blend-mode:difference;transition:transform .1s ease}
#cursor-ring{width:30px;height:30px;border:1px solid rgba(255,255,255,.6);mix-blend-mode:difference;transition:width .2s,height .2s,transform .15s}
body.cursor-light #cursor-dot{background:var(--black)}
body.cursor-light #cursor-ring{border-color:rgba(0,0,0,.4)}

/* NAV */
#main-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:24px 48px;mix-blend-mode:difference}
.nav-brand{font-size:.78rem;font-weight:800;letter-spacing:.04em;color:var(--white)}
.nav-cta-link{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--white);border:1px solid rgba(255,255,255,.35);padding:9px 20px;transition:var(--ease)}
.nav-cta-link:hover{background:var(--white);color:var(--black)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;font-family:var(--font);font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:14px 28px;border:1px solid;transition:var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn-white{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-white:hover{background:var(--off)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.4)}
.btn-outline-white:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-outline{background:transparent;color:var(--black);border-color:var(--black)}
.btn-outline:hover{background:var(--black);color:var(--white)}
.btn-ghost{background:transparent;color:var(--dim);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--black);color:var(--black)}
.btn-inline{background:transparent;color:var(--black);border-color:var(--black);padding:9px 18px;font-size:.7rem}
.btn-inline:hover{background:var(--black);color:var(--white)}
.btn-large{padding:18px 40px;font-size:.85rem}
.container{max-width:1100px;margin:0 auto;padding:0 48px}
.bg-off{background-color:var(--off)!important}
.bg-dots{background-color:var(--white)!important;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:24px 24px}
.section-label{font-size:.65rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);margin-bottom:16px;display:block}
.section-title{font-size:clamp(2rem,5vw,4rem);font-weight:900;line-height:1.05;letter-spacing:-.03em;margin-bottom:24px}
.section-title em{font-style:normal;opacity:.3}
.section-sub{font-size:1rem;color:rgba(255,255,255,.45);max-width:500px;line-height:1.7}
.section-header{margin-bottom:64px}
.section-header--light .section-label{color:rgba(255,255,255,.35)}
.section-header--light .section-title{color:var(--white)}

/* ── HERO ── */
#hero{position:relative;min-height:100vh;min-height:100dvh;background:var(--black);display:flex;align-items:center;justify-content:center;overflow:hidden}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-inner{position:relative;z-index:2;text-align:center;color:var(--white);padding:0 24px}
.hero-eyebrow{font-size:.68rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:28px;display:block}
.hero-headline{font-size:clamp(3rem,9vw,8rem);font-weight:900;line-height:.98;letter-spacing:-.04em;margin-bottom:28px}
.hero-headline em{font-style:normal;display:block;color:rgba(255,255,255,.35)}
.hero-specialty{font-size:.72rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-bottom:16px}
.hero-subline{font-size:clamp(.95rem,1.7vw,1.15rem);line-height:1.7;color:rgba(255,255,255,.48);max-width:620px;margin:0 auto 44px}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ── ARGUMENT PANELS ── */
#scroll-story{}
.arg-panel{padding:100px 48px;display:flex;align-items:center;min-height:60vh}
.arg-panel--white{background:var(--white)}
.arg-panel--black{background:var(--black);color:var(--white)}
.arg-panel-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:80px 1fr;gap:40px;align-items:start;width:100%;
  opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.arg-panel-inner.in-view{opacity:1;transform:translateY(0)}
.arg-num{font-size:.68rem;font-weight:800;letter-spacing:.18em;color:var(--dim);padding-top:18px}
.arg-panel--black .arg-num{color:rgba(255,255,255,.25)}
.arg-big{font-size:clamp(2.2rem,5vw,4.5rem);font-weight:900;letter-spacing:-.04em;line-height:1.0;margin-bottom:20px}
.arg-desc{font-size:1.05rem;line-height:1.75;color:var(--dim);max-width:520px}
.arg-panel--black .arg-desc{color:rgba(255,255,255,.45)}

/* ── FAQ ACCORDION ── */
#objections{background:var(--black);padding:120px 0 118px;position:relative;overflow:hidden}
#objections::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:rgba(255,255,255,.1);pointer-events:none}
#objections .section-label{color:rgba(255,255,255,.3)}
#objections .section-title{color:var(--white)}
.faq-list{display:flex;flex-direction:column;gap:16px;margin-bottom:64px}
.faq-row{border:1px solid rgba(255,255,255,.15);border-radius:16px;cursor:pointer;transition:all var(--ease);color:var(--white);background:var(--black)}
.faq-row:hover,.faq-row:focus{outline:none;border-color:rgba(255,255,255,.4);transform:translateY(-4px)}
.faq-row.open{background:var(--white);color:var(--black);transform:scale(1.02);border-color:var(--white);box-shadow:0 30px 60px rgba(0,0,0,.6);margin:16px 0;border-radius:24px;z-index:2;position:relative}
.faq-header{display:grid;grid-template-columns:50px 1fr 44px;gap:20px;align-items:center;padding:32px 40px}
.faq-num{font-size:.75rem;font-weight:800;letter-spacing:.22em;color:rgba(255,255,255,.4);transition:color var(--ease)}
.faq-row.open .faq-num{color:var(--dim)}
.faq-q{font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:800;line-height:1.3;letter-spacing:-.02em}
.faq-icon{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;justify-content:center;align-items:center;font-size:1.8rem;font-weight:300;transition:all var(--ease);color:var(--white)}
.faq-row:hover .faq-icon{background:rgba(255,255,255,.1)}
.faq-row.open .faq-icon{transform:rotate(135deg);background:var(--black);color:var(--white);border-color:var(--black)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .7s cubic-bezier(.25,1,.5,1)}
.faq-row.open .faq-answer{max-height:400px}
.faq-answer p{font-size:1.05rem;line-height:1.7;color:rgba(255,255,255,.6);padding:0 40px 48px 110px;max-width:850px;transition:color var(--ease)}
.faq-row.open .faq-answer p{color:rgba(0,0,0,.75)}
.faq-closing{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.26);text-align:center;padding:24px 0 0;position:relative}

/* ── CANDIDATE BUILDER ── */
#candidate-builder{position:relative;overflow:hidden;background:var(--black);color:var(--white);padding:112px 0 140px;scroll-margin-top:88px}
#candidate-builder::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.024) 1px,transparent 1px);background-size:48px 48px;mask-image:linear-gradient(180deg,transparent 0,black 30%,black 86%,transparent 100%);pointer-events:none}
#candidate-builder::after{content:'candidate fit';position:absolute;right:-.08em;bottom:-.18em;font-size:clamp(5rem,16vw,13rem);font-weight:900;letter-spacing:-.06em;line-height:.8;color:rgba(255,255,255,.022);white-space:nowrap;pointer-events:none}
#candidate-builder .container{position:relative;z-index:1}
#candidate-builder .section-label{color:rgba(255,255,255,.42)}
#candidate-builder .section-title{color:var(--white);max-width:820px}
#candidate-builder .section-sub{color:rgba(255,255,255,.62)}
#candidate-builder .section-header{position:relative;margin-bottom:56px;padding-top:34px}
#candidate-builder .section-header::before{content:'';position:absolute;left:0;top:0;width:min(420px,46vw);height:1px;background:rgba(255,255,255,.24)}
.builder-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,380px);gap:clamp(28px,6vw,70px);align-items:start}
.builder-chips{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-content:start}
.chip{min-height:54px;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:14px 18px;border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.72);background:rgba(255,255,255,.045);transition:var(--ease);text-align:left;box-shadow:inset 0 0 0 1px rgba(255,255,255,.02)}
.chip:hover{border-color:rgba(255,255,255,.65);color:var(--white);background:rgba(255,255,255,.1);transform:translateY(-2px)}
.chip.active{background:var(--white);color:var(--black);border-color:var(--white);box-shadow:0 14px 40px rgba(0,0,0,.28)}
.candidate-card{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.16);padding:34px 34px 30px;min-height:252px;display:flex;flex-direction:column;justify-content:center;background:rgba(255,255,255,.94);color:var(--black);box-shadow:0 22px 54px rgba(0,0,0,.28)}
.candidate-card::before{content:'';position:absolute;inset:12px;border:1px solid rgba(0,0,0,.08);pointer-events:none}
.candidate-card::after{content:attr(data-match);position:absolute;right:22px;top:18px;font-size:clamp(2.8rem,6vw,4.8rem);font-weight:900;letter-spacing:-.08em;color:rgba(0,0,0,.05);line-height:1;pointer-events:none}
.candidate-label{position:relative;font-size:.6rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(0,0,0,.48);margin-bottom:18px;display:block}
.candidate-state{position:relative;font-size:clamp(1.55rem,2.6vw,2.35rem);font-weight:900;letter-spacing:-.045em;line-height:1.08;transition:opacity .35s ease;min-height:2.4em;display:flex;align-items:center;color:var(--black);max-width:11ch}
.candidate-traits{position:relative;display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.candidate-trait-tag{font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border:1px solid rgba(0,0,0,.2);color:var(--white);background:var(--black)}

/* ── SKILLS ── */
#skills.bg-off{background:var(--off)!important;padding:120px 0 130px;position:relative;overflow:hidden}
#skills::before{content:'';position:absolute;left:0;right:0;top:0;height:1px;background:rgba(0,0,0,.12)}
#skills .container{position:relative;z-index:1}
#skills .section-header{display:block;max-width:820px;border-bottom:1px solid rgba(0,0,0,.14);padding-bottom:34px;margin-bottom:54px}
#skills .section-label{margin-bottom:18px}
#skills .section-title{margin-bottom:0}
#skills .section-header::after{content:'tools / taste / structure';display:block;font-size:.65rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(0,0,0,.42);margin-top:22px}
.skills-layout{display:grid;grid-template-columns:minmax(340px,420px) minmax(0,1fr);gap:54px;align-items:start}
.skills-tags{counter-reset:skill;display:flex;flex-direction:column;border-top:1px solid rgba(0,0,0,.16)}
.skill-tag{counter-increment:skill;position:relative;display:grid;grid-template-columns:54px minmax(0,1fr) auto;align-items:center;min-height:58px;width:100%;font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:0 18px 0 0;border-bottom:1px solid rgba(0,0,0,.14);color:rgba(0,0,0,.72);background:transparent;transition:color .25s ease,background .25s ease,padding .25s ease;cursor:pointer;text-align:left;overflow-wrap:anywhere}
.skill-tag::before{content:counter(skill,decimal-leading-zero);font-size:.62rem;font-weight:800;letter-spacing:.14em;color:rgba(0,0,0,.34)}
.skill-tag::after{content:attr(data-level);font-size:.58rem;font-weight:800;letter-spacing:.16em;color:rgba(0,0,0,.34)}
.skill-tag:hover,.skill-tag.active{background:var(--black);color:var(--white);padding-left:18px}
.skill-tag:hover::before,.skill-tag.active::before,.skill-tag:hover::after,.skill-tag.active::after{color:rgba(255,255,255,.46)}
.skills-panel{position:sticky;top:100px;min-height:300px;padding:36px 34px;display:flex;flex-direction:column;justify-content:flex-end;background:var(--black);color:var(--white);border:1px solid var(--black);order:-1;overflow:hidden}
.skills-panel::before{content:'selected skill';position:absolute;left:34px;top:30px;font-size:.6rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.32)}
.skills-panel::after{content:'';position:absolute;left:34px;right:34px;top:58px;height:1px;background:rgba(255,255,255,.16)}
.skills-panel-content{padding-top:58px}
.skills-panel-hint{font-size:.92rem;color:rgba(255,255,255,.54);line-height:1.7;max-width:220px}
.skills-panel-level{font-size:.6rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--black);background:var(--white);padding:5px 10px;display:inline-block;margin-bottom:18px}
.skills-panel-name{font-size:clamp(1.85rem,3.2vw,2.6rem);font-weight:900;letter-spacing:-.035em;line-height:1.02;margin-bottom:16px;color:var(--white);overflow-wrap:anywhere;word-break:normal}
.skills-panel-info{font-size:.95rem;color:rgba(255,255,255,.64);line-height:1.75;max-width:270px}

/* ── TIMELINE ── */
#timeline{background:var(--black);color:var(--white);padding:120px 0}
.timeline-track{position:relative;padding-left:36px}
.timeline-line{position:absolute;left:0;top:0;width:1px;height:0;background:rgba(255,255,255,.15);transition:height 1s ease}
.timeline-item{position:relative;margin-bottom:40px;opacity:0;transform:translateX(-16px);transition:opacity .6s ease,transform .6s ease}
.timeline-item.in-view{opacity:1;transform:translateX(0)}
.tl-connector{position:absolute;left:-36px;top:28px;width:36px;height:1px;background:rgba(255,255,255,.15)}
.tl-connector::before{content:'';position:absolute;right:0;top:-4px;width:8px;height:8px;border:1px solid rgba(255,255,255,.3);border-radius:50%;background:var(--black)}
.timeline-item--current .tl-connector::before{background:var(--accent);border-color:var(--accent)}
.tl-card{border:1px solid rgba(255,255,255,.08);padding:28px 32px;transition:border-color var(--ease)}
.tl-card:hover{border-color:rgba(255,255,255,.25)}
.tl-level{font-size:.6rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.25);display:block;margin-bottom:10px}
.tl-title{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}
.tl-sub{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:14px}
.tl-text{font-size:.88rem;color:rgba(255,255,255,.45);line-height:1.7;margin-bottom:18px}
.tl-badge{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.35);display:inline-block}
.tl-badge--accent{border-color:var(--accent);color:var(--accent)}

/* ── PROJECTS ── */
#projects{background:var(--white);padding:120px 0}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.project-card{overflow:hidden;background:var(--white);border:1px solid var(--border);border-radius:8px;transition:var(--ease);cursor:pointer;position:relative}
.project-card:hover{background:var(--white);transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.12)}
.project-card:focus{outline:none;background:var(--off);box-shadow:0 0 0 2px var(--black)}
.project-img{height:250px;transition:transform .6s ease;position:relative;overflow:hidden;background:var(--black);display:flex;align-items:center;justify-content:center}
.project-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.36));opacity:.65;transition:opacity .35s ease}
.project-img img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .7s ease,filter .7s ease}
.project-card:hover .project-img img{transform:scale(1.06);filter:contrast(1.05)}
.project-img--logo{background:var(--black);padding:0}
.project-img--logo img{object-fit:cover;filter:none;transform:scale(1.08)}
.project-img--screen img{width:100%;height:100%;object-fit:cover}
.project-img--mindease-logo{background:var(--white);padding:0}
.project-img--mindease-logo img{object-fit:cover;filter:none;transform:scale(1.08)}
.project-info{padding:26px 28px 32px;min-height:178px;position:relative}
.project-meta{font-size:.6rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);margin-bottom:10px;line-height:1.5;overflow-wrap:anywhere}
.project-title{font-size:1.25rem;font-weight:900;letter-spacing:-.035em;line-height:1.16;margin-bottom:12px;overflow-wrap:anywhere}
.project-reveal{font-size:.84rem;color:var(--dim);line-height:1.65;margin-bottom:20px;max-height:none;overflow:visible;opacity:1;overflow-wrap:anywhere}
.project-cta{opacity:1;display:inline-flex}
.project-modal{position:fixed;inset:0;z-index:500;display:grid;place-items:start center;padding:28px 32px;overflow-y:auto}
.project-modal[hidden]{display:none}
.project-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}
.project-modal-card{position:relative;width:min(860px,100%);max-height:calc(100vh - 56px);overflow-y:auto;background:var(--black);color:var(--white);padding:48px;border:1px solid rgba(255,255,255,.16);box-shadow:0 40px 90px rgba(0,0,0,.45)}
.project-modal-close{position:absolute;right:22px;top:18px;width:42px;height:42px;border:1px solid rgba(255,255,255,.24);border-radius:50%;color:var(--white);font-size:1.8rem;font-weight:300;line-height:1;transform:rotate(45deg);transition:var(--ease)}
.project-modal-close:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.project-modal-label{font-size:.62rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:18px;max-width:720px}
.project-modal-title{font-size:clamp(2.2rem,5vw,4rem);font-weight:900;letter-spacing:-.045em;line-height:1;margin-bottom:22px;max-width:720px}
.project-modal-text{font-size:1rem;line-height:1.8;color:rgba(255,255,255,.68);max-width:680px;margin-bottom:38px}
.project-modal-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,.14);border-left:1px solid rgba(255,255,255,.14)}
.project-modal-grid div{padding:22px;border-right:1px solid rgba(255,255,255,.14);border-bottom:1px solid rgba(255,255,255,.14)}
.project-modal-grid span{display:block;font-size:.58rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.34);margin-bottom:10px}
.project-modal-grid p{font-size:.88rem;line-height:1.6;color:rgba(255,255,255,.72)}
.project-modal-link{margin-top:28px}
.project-modal-link[aria-disabled="true"]{opacity:.45;pointer-events:none}
.project-mockups{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;align-items:start;margin-top:36px;padding:0;border:0;background:transparent}
.project-mockup{height:auto;min-height:0;border:1px solid rgba(255,255,255,.16);border-radius:8px;background:transparent;overflow:visible;display:block}
.project-mockup img{width:100%;height:auto;max-height:520px;object-fit:contain;display:block;background:transparent;border-radius:8px}
.project-mockup--story{height:auto}
body.modal-open{overflow:hidden}

/* ── NOTICES ── */
#notices{background:var(--black);color:var(--white);padding:120px 0}
.notices-list{margin-bottom:80px}
.notice-line{font-size:clamp(1.3rem,3.5vw,2.6rem);font-weight:800;letter-spacing:-.03em;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.07);opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
.notice-line.in-view{opacity:1;transform:translateY(0)}
.notices-closing{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease;margin-top:60px}
.notices-closing.in-view{opacity:1;transform:translateY(0)}
.notices-closing-main{font-size:clamp(2rem,5vw,4rem);font-weight:900;letter-spacing:-.04em;line-height:1.05;margin-bottom:16px}
.notices-closing-sub{font-size:.9rem;color:rgba(255,255,255,.35)}

/* ── ABOUT ── */
#about{background:var(--white);padding:120px 0}
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:start}
.about-headline{font-size:clamp(2rem,4.5vw,3.5rem);font-weight:900;letter-spacing:-.04em;margin-bottom:28px;line-height:1}
.about-text{font-size:.95rem;color:var(--dim);line-height:1.8;margin-bottom:18px}
.about-facts-col{display:flex;flex-direction:column;gap:0;border:1px solid var(--border)}
.fact-card{padding:16px 20px;font-size:.78rem;font-weight:600;line-height:1.45;border-bottom:1px solid var(--border);letter-spacing:.01em;color:var(--dim)}
.fact-card:last-child{border-bottom:none}
.fact-card--accent{background:var(--black);color:var(--white);font-weight:700;letter-spacing:.04em}

/* SIGNAL WIDGET */
.signal-widget{margin-top:48px;border:1px solid var(--border);max-width:420px;background:rgba(255,255,255,.45)}
.signal-button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 20px;border-bottom:1px solid var(--border);color:var(--black);text-align:left;transition:background .25s ease}
.signal-button:hover{background:var(--black);color:var(--white)}
.signal-button span{font-size:.76rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;line-height:1.4}
.signal-button strong{font-size:.6rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--dim)}
.signal-button:hover strong{color:rgba(255,255,255,.55)}
.signal-bars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);height:46px}
.signal-bars span{background:var(--off);transition:background .35s ease,transform .35s ease}
.signal-widget.active .signal-bars span{background:var(--black)}
.signal-widget.active .signal-bars span:nth-child(2){transition-delay:.08s}
.signal-widget.active .signal-bars span:nth-child(3){transition-delay:.16s}
.signal-widget.active .signal-button{background:var(--black);color:var(--white)}
.signal-widget.active .signal-button strong{color:rgba(255,255,255,.55)}
.signal-result{font-size:.84rem;font-weight:600;line-height:1.6;color:var(--dim);padding:18px 20px}

/* ── CTA ── */
#cta{background:var(--black);color:var(--white);padding:0 0 0;overflow:hidden;position:relative}
.cta-bg-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:clamp(8rem,20vw,18rem);font-weight:900;letter-spacing:-.06em;color:rgba(255,255,255,.03);white-space:nowrap;pointer-events:none;user-select:none;line-height:1}
.cta-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;min-height:80vh;}
.cta-left{padding:80px 60px 80px 48px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid rgba(255,255,255,.08)}
.cta-left .section-label{color:rgba(255,255,255,.25);margin-bottom:24px}
.cta-headline{font-size:clamp(2.2rem,5vw,4.5rem);font-weight:900;letter-spacing:-.04em;line-height:1.0;margin-bottom:20px}
.cta-sub{font-size:1rem;color:rgba(255,255,255,.4);line-height:1.7;margin-bottom:0}
.cta-right{padding:80px 48px 80px 60px;display:flex;flex-direction:column;justify-content:center;gap:32px}
.cta-buttons{display:flex;flex-direction:column;gap:12px}
.cta-buttons .btn{justify-content:flex-start;gap:12px}
.cta-buttons .btn-white{background:var(--white);color:var(--black);border-color:var(--white)}
.cta-buttons .btn-white:hover{background:var(--off)}
.cta-buttons .btn-outline{color:rgba(255,255,255,.6);border-color:rgba(255,255,255,.2)}
.cta-buttons .btn-outline:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.cta-buttons .btn-ghost{color:rgba(255,255,255,.3);border-color:rgba(255,255,255,.08)}
.cta-buttons .btn-ghost:hover{border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.6)}
.cta-checkbox{display:flex;align-items:center;gap:16px;cursor:pointer;text-align:left;padding:20px 24px;border:1px solid rgba(255,255,255,.08);transition:border-color .3s ease,background .3s ease}
.cta-checkbox:hover,.cta-checkbox:focus{outline:none;border-color:rgba(255,255,255,.2)}
.checkbox-box{width:20px;height:20px;border:1px solid rgba(255,255,255,.2);flex-shrink:0;position:relative;display:grid;place-items:center;transition:background .25s,border-color .25s,transform .3s cubic-bezier(.34,1.56,.64,1)}
.cta-checkbox[aria-checked="true"]{background:var(--accent);border-color:var(--accent)}
.cta-checkbox[aria-checked="true"] .checkbox-box{background:var(--black);border-color:var(--black);transform:scale(1.1)}
.cta-checkbox[aria-checked="true"] .checkbox-box::after{content:'';width:9px;height:5px;border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:translateY(-1px) rotate(-45deg)}
.checkbox-label{font-size:.82rem;font-weight:600;color:rgba(255,255,255,.35);line-height:1.4;transition:color .25s}
.cta-checkbox[aria-checked="true"] .checkbox-label{color:var(--black);font-weight:700}
footer{border-top:1px solid rgba(255,255,255,.07);padding:22px 48px;display:flex;justify-content:space-between;font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.15);position:relative;z-index:1}
footer a{color:rgba(255,255,255,.28);transition:color .25s ease}
footer a:hover{color:var(--white)}
.footer-note{text-transform:none;letter-spacing:0;font-style:italic}

/* LEGAL */
.legal-page{cursor:auto;background:var(--off);color:var(--black)}
.legal-page #cursor-dot,.legal-page #cursor-ring{display:none}
.legal-main{max-width:920px;margin:0 auto;padding:48px 48px 96px}
.legal-back{display:inline-flex;margin-bottom:80px;font-size:.68rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);border:1px solid var(--border);padding:10px 16px;transition:var(--ease)}
.legal-back:hover{background:var(--black);color:var(--white);border-color:var(--black)}
.legal-hero{border-bottom:1px solid rgba(0,0,0,.14);padding-bottom:48px;margin-bottom:56px}
.legal-hero h1{font-size:clamp(3rem,8vw,6rem);font-weight:900;letter-spacing:-.055em;line-height:.95}
.legal-hero h1 em{font-style:normal;color:rgba(0,0,0,.34)}
.legal-section{background:var(--white);border:1px solid var(--border);padding:42px;margin-bottom:24px}
.legal-section h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:900;letter-spacing:-.04em;line-height:1;margin-bottom:26px}
.legal-section h3{font-size:.75rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin:30px 0 10px}
.legal-section p,.legal-section li{font-size:.98rem;line-height:1.8;color:rgba(0,0,0,.68)}
.legal-section a{text-decoration:underline;text-underline-offset:3px}
.legal-section ul{list-style:disc;margin:12px 0 22px 22px}
.legal-kicker,.legal-stand{font-weight:700;color:var(--black)!important}

/* RESPONSIVE */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
@media(max-width:1024px){
  .container{max-width:860px}
  .projects-grid{grid-template-columns:1fr 1fr}
  .builder-layout,.about-grid,.skills-layout,.cta-inner{grid-template-columns:1fr;gap:40px}
  .skills-panel{position:relative;top:auto;order:0;min-height:260px}
  .skills-tags{order:1}
  .about-grid{gap:48px}
  .signal-widget{max-width:100%}
  .cta-left{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
  .cta-right{padding:56px 48px}
  .project-modal-card{width:min(760px,100%)}
  .project-mockups{grid-template-columns:1fr 1fr}
  .project-mockup--story{height:auto}
}
@media(max-width:768px){
  .container{padding:0 24px}
  #main-nav{padding:18px 24px}
  .btn{width:100%;justify-content:center;text-align:center;padding:13px 18px}
  #hero{padding:104px 0 122px;min-height:100svh;align-items:center}
  .hero-inner{padding:0 20px}
  .hero-eyebrow{font-size:.58rem;letter-spacing:.18em;margin-bottom:20px}
  .hero-headline{font-size:clamp(2.55rem,13vw,4.4rem);letter-spacing:-.035em;margin-bottom:24px}
  .hero-specialty{font-size:.58rem;letter-spacing:.12em;line-height:1.7;max-width:300px;margin:0 auto 14px}
  .hero-subline{font-size:.95rem;line-height:1.65;margin-bottom:28px}
  .hero-ctas{gap:10px;position:relative;z-index:3}
  .section-header{margin-bottom:42px}
  .section-title{font-size:clamp(2.15rem,11vw,3.4rem);letter-spacing:-.035em}
  .arg-panel{padding:64px 24px;min-height:auto}
  .arg-panel-inner{grid-template-columns:1fr;gap:12px}
  .arg-num{padding-top:0}
  .arg-big{font-size:clamp(2.1rem,11vw,3.4rem)}
  .arg-desc{font-size:.98rem}
  .faq-header{grid-template-columns:40px 1fr 30px;padding:24px 20px}
  .faq-row.open{transform:none;border-radius:18px}
  .faq-icon{width:34px;height:34px;font-size:1.45rem}
  .faq-answer p{padding:0 20px 32px 20px}
  #objections{padding:88px 0 92px}
  #objections::after{height:1px}
  #candidate-builder{padding:86px 0 88px;scroll-margin-top:72px}
  #candidate-builder::after{font-size:5rem;right:-.4em}
  #skills.bg-off{padding:88px 0}
  #candidate-builder .section-header{padding-top:20px;margin-bottom:44px}
  #candidate-builder .section-header::before{width:100%}
  .builder-layout{gap:28px}
  .builder-chips{grid-template-columns:1fr}
  .chip{min-height:50px}
  .skill-tag{grid-template-columns:46px 1fr;gap:10px;padding-right:0}
  .skill-tag::after{display:none}
  .skills-layout{gap:28px}
  .skills-panel{min-height:240px}
  .skills-panel::before{left:24px;top:24px}
  .skills-panel::after{left:24px;right:24px;top:52px}
  .skills-panel-content{padding-top:48px}
  .skills-panel-name{font-size:clamp(1.8rem,10vw,2.5rem)}
  .candidate-card,.skills-panel{padding:30px 24px}
  .candidate-card{min-height:230px}
  .candidate-state{max-width:12ch}
  .skills-panel{box-shadow:none}
  #timeline,#projects,#notices,#about{padding:88px 0}
  .timeline-track{padding-left:24px}
  .tl-connector{left:-24px;width:24px}
  .tl-card{padding:24px 22px}
  .projects-grid{grid-template-columns:1fr;border:none}
  .project-card{border:1px solid var(--border);margin-bottom:2px}
  .project-img{height:220px}
  .project-info{min-height:auto;padding:24px}
  .project-title{font-size:1.18rem}
  .project-modal{display:block;padding:0;background:var(--black);overflow-y:auto}
  .project-modal-card{width:100%;min-height:100vh;min-height:100dvh;max-height:none;overflow:visible;border:0;box-shadow:none;padding:76px 24px 32px}
  .project-modal-title{font-size:clamp(2rem,12vw,3rem);padding-right:44px}
  .project-modal-text{font-size:.95rem;margin-bottom:28px}
  .project-modal-grid{grid-template-columns:1fr}
  .project-mockups{grid-template-columns:1fr;padding:0}
  .project-mockup,.project-mockup--story,.project-mockup--carousel{height:auto;min-height:0;aspect-ratio:auto;transform:none}
  .project-modal-close{position:fixed;right:16px;top:16px;z-index:2;background:var(--black)}
  .notice-line{font-size:clamp(1.6rem,8vw,2.4rem);line-height:1.12}
  .notices-list{margin-bottom:56px}
  .notices-closing-main{font-size:clamp(2.1rem,11vw,3.4rem)}
  .about-facts-col{margin-top:4px}
  .signal-button{align-items:flex-start;flex-direction:column;gap:8px}
  .cta-buttons{flex-direction:column;align-items:center}
  .cta-inner{padding:0 24px 60px;min-height:auto}
  .cta-left,.cta-right{padding:64px 0}
  .cta-headline{font-size:clamp(2.2rem,12vw,3.6rem)}
  .cta-buttons,.cta-buttons .btn{width:100%}
  .cta-checkbox{padding:18px;align-items:flex-start}
  footer{flex-direction:column;gap:6px;text-align:center;padding:20px 24px}
  .legal-main{padding:32px 24px 72px}
  .legal-back{margin-bottom:54px}
  .legal-section{padding:28px 22px}
}

@media(max-width:480px){
  body{cursor:auto}
  #cursor-dot,#cursor-ring{display:none}
  #main-nav{padding:14px 18px}
  .nav-cta-link{padding:8px 14px;font-size:.62rem}
  .container{padding:0 18px}
  .hero-headline{font-size:clamp(2.25rem,14vw,3.6rem)}
  .hero-specialty{max-width:250px}
  .arg-panel{padding:56px 18px}
  #objections,#timeline,#projects,#notices,#about{padding:76px 0}
  .faq-header{grid-template-columns:32px 1fr 28px;gap:12px;padding:20px 16px}
  .faq-answer p{padding:0 16px 28px}
  #candidate-builder{padding:76px 0}
  .candidate-card::after{font-size:3.4rem;right:16px;top:18px}
  .project-img{height:190px}
  .project-modal-card{padding:76px 18px 28px}
  .project-mockup,.project-mockup--story,.project-mockup--carousel{height:auto}
  .skill-tag{font-size:.72rem;letter-spacing:.04em}
  .signal-widget{margin-top:36px}
  .cta-checkbox{gap:12px}
  footer{font-size:.58rem}
  .legal-main{padding:26px 18px 60px}
  .legal-hero{margin-bottom:36px;padding-bottom:34px}
  .legal-section{padding:24px 18px}
}
