/* ============================================================
   ATLAS РОСТА — единый дизайн-язык
   Центр онлайн-обучения Светланы Сомовой
   Ботанический атлас: хвойно-зелёная палитра + Playfair/Geologica/PT Mono
   ============================================================ */
:root{
  --paper: oklch(96.5% .013 145);
  --paper-2: oklch(93.5% .018 145);
  --paper-card: oklch(98.5% .009 140);
  --ink: oklch(22% .034 155);
  --ink-soft: oklch(40% .030 155);
  --ink-faint: oklch(56% .024 150);
  --pine: oklch(34% .075 155);
  --moss: oklch(50% .11 150);
  --moss-bright: oklch(64% .13 148);
  --ochre: oklch(66% .12 74);
  --berry: oklch(49% .14 22);
  --forest: oklch(20% .045 156);
  --forest-2: oklch(25% .052 156);
  --forest-line: oklch(40% .05 152 / .35);
  --line: oklch(84% .025 142);
  --line-strong: oklch(72% .04 145);
  --glow: oklch(60% .12 150 / .5);
  --shadow: 0 28px 70px -30px oklch(28% .06 150 / .5);
  --shadow-soft: 0 14px 36px -22px oklch(28% .06 150 / .38);
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Geologica', system-ui, -apple-system, sans-serif;
  --font-mono: 'PT Mono', ui-monospace, monospace;
  --shell: 1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{background:var(--paper);scroll-behavior:smooth;scroll-padding-top:88px;overflow-x:hidden}
html,body{color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.62;-webkit-font-smoothing:antialiased}
body{background:transparent;min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
a{color:inherit;text-decoration:none}
img,svg{display:block}

/* фон */
.flora{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.flora__mesh{position:absolute;inset:0;background:
  radial-gradient(60% 50% at 12% 8%, oklch(90% .04 150 / .7), transparent 70%),
  radial-gradient(50% 45% at 88% 92%, oklch(88% .05 120 / .55), transparent 70%),
  radial-gradient(40% 40% at 95% 20%, oklch(92% .04 70 / .5), transparent 70%)}
.flora svg{position:absolute}
.flora__1{top:-50px;left:-70px;width:360px;color:var(--moss);opacity:.10;transform:rotate(8deg)}
.flora__2{bottom:-90px;right:-80px;width:440px;color:var(--pine);opacity:.08;transform:rotate(-12deg)}
.flora__grain{position:absolute;inset:0;opacity:.6;mix-blend-mode:multiply;
  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='.92' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 .22 0 0 0 0 .3 0 0 0 0 .2 0 0 0 .045 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}

.shell{max-width:var(--shell);margin:0 auto;padding:0 36px;width:100%}
.eyebrow{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--moss);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;display:inline-block}
.sec-h{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,4vw,48px);line-height:1.06;letter-spacing:-.015em;color:var(--ink)}

/* HEADER */
.hd{position:fixed;top:0;left:0;right:0;z-index:80;backdrop-filter:blur(16px);background:oklch(96.5% .013 145 / .85);border-bottom:1px solid var(--line)}
.hd__row{max-width:var(--shell);margin:0 auto;padding:13px 36px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand__seal{width:42px;height:42px;border:1.5px solid var(--pine);border-radius:50%;display:grid;place-items:center;color:var(--pine);flex-shrink:0}
.brand__seal svg{width:25px;height:25px}
.brand__txt{display:flex;flex-direction:column;line-height:1.04}
.brand__name{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink)}
.brand__sub{font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint);margin-top:2px}
.hd__nav{display:flex;gap:4px}
.hd__nav a{font-size:13.5px;color:var(--ink-soft);padding:8px 14px;border-radius:999px;border:1px solid transparent;white-space:nowrap;transition:.2s}
.hd__nav a:hover,.hd__nav a.is-active{color:var(--pine);background:var(--paper-2);border-color:var(--line)}
.hd__cta{display:flex;align-items:center;gap:10px}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line-strong);border-radius:10px;background:var(--paper-card);color:var(--ink);cursor:pointer;align-items:center;justify-content:center}
.burger svg{width:22px;height:22px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-body);font-size:14.5px;font-weight:500;padding:11px 22px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.22s;white-space:nowrap;text-align:center}
.btn--solid{background:var(--pine);color:var(--paper)}
.btn--solid:hover{background:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.btn--ghost{border-color:var(--line-strong);color:var(--ink)}
.btn--ghost:hover{border-color:var(--pine);color:var(--pine)}
.btn--light{background:var(--moss-bright);color:var(--forest);font-weight:600}
.btn--light:hover{transform:translateY(-2px);box-shadow:0 12px 30px -12px var(--glow)}
.btn--lg{padding:15px 30px;font-size:16px}
.btn--full{width:100%}

/* HERO (главная) */
.hero{padding:138px 0 60px;position:relative}
.hero__coord{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(70% 60% at 70% 30%,#000,transparent 75%)}
.hero__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center}
.hero__vol{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:24px;display:flex;gap:16px;flex-wrap:wrap}
.hero__vol span{padding-bottom:4px;border-bottom:1px solid var(--line-strong)}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,5.6vw,72px);line-height:1.02;letter-spacing:-.02em;color:var(--ink);margin-bottom:24px}
.hero h1 em{font-style:italic;color:var(--moss);font-weight:600}
.hero__lede{font-size:18px;line-height:1.62;color:var(--ink-soft);max-width:520px;margin-bottom:34px}
.hero__lede strong{color:var(--ink);font-weight:600}
.hero__cta{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:38px}
.hero__facts{display:grid;grid-template-columns:repeat(4,auto);gap:30px;justify-content:start;padding-top:28px;border-top:1px solid var(--line)}
.fact__n{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--pine);line-height:1}
.fact__l{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-top:7px}
.hero__plate{position:relative;aspect-ratio:.86;background:var(--paper-card);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:24px;display:flex;flex-direction:column;overflow:hidden}
.hero__plate::before{content:"";position:absolute;inset:12px;border:1px solid var(--line);border-radius:4px;pointer-events:none}
.hero__plate::after{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) .5px,transparent .5px),linear-gradient(90deg,var(--line) .5px,transparent .5px);background-size:22px 22px;opacity:.3;pointer-events:none}
.plate__tag{position:absolute;top:-12px;right:22px;background:var(--ochre);color:var(--ink);font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:3px;transform:rotate(-3deg);box-shadow:var(--shadow-soft);z-index:2}
.plate__art{flex:1;display:grid;place-items:center;color:var(--pine);padding:10px;position:relative;z-index:1}
.plate__art svg{width:100%;height:100%;max-height:330px}
.plate__cap{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint);text-align:center;line-height:1.55;border-top:1px solid var(--line);padding-top:13px;position:relative;z-index:1}
.plate__cap i{font-style:italic;font-family:var(--font-display);color:var(--ink);font-size:13px}
.plate__cap b{color:var(--pine);font-weight:400}

/* PAGE-HERO (внутренние страницы) */
.page-hero{padding:128px 0 40px;position:relative}
.page-hero__coord{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:.45;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(80% 70% at 50% 0%,#000,transparent 80%)}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,5vw,60px);line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin-bottom:20px;max-width:18ch}
.page-hero h1 em{font-style:italic;color:var(--moss)}
.page-hero__lede{font-size:18px;color:var(--ink-soft);max-width:600px;line-height:1.6}

/* PATH */
.path{padding:84px 0;position:relative}
.path__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.path__art{position:relative;aspect-ratio:1;display:grid;place-items:center}
.path__art svg{width:100%;height:100%;max-width:420px;color:var(--pine)}
.path__copy .eyebrow{margin-bottom:18px}
.path__copy h2{margin-bottom:22px}
.path__copy p{font-size:16.5px;color:var(--ink-soft);margin-bottom:16px;max-width:560px}
.path__copy p strong{color:var(--ink);font-weight:600}
.path__sign{margin-top:26px;font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--pine);display:flex;align-items:center;gap:14px}
.path__sign::before{content:"";width:40px;height:1px;background:var(--line-strong)}

/* LINES */
.lines{padding:84px 0}
.lines__head{max-width:660px;margin-bottom:46px}
.lines__head .eyebrow{margin-bottom:16px}
.lines__head p{font-size:16px;color:var(--ink-soft);margin-top:14px}
.lines__grid{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--line)}
.lcard{background:var(--paper-card);padding:30px 24px;display:flex;flex-direction:column;gap:14px;transition:.25s}
.lcard:not(:last-child){border-right:1px solid var(--line)}
.lcard:hover{background:var(--forest);color:var(--paper)}
.lcard:hover .lcard__n,.lcard:hover h3{color:var(--moss-bright)}
.lcard:hover .lcard__art{color:var(--moss-bright)}
.lcard:hover p{color:oklch(85% .02 145)}
.lcard__art{width:46px;height:46px;color:var(--pine);transition:.25s}
.lcard__art svg{width:100%;height:100%}
.lcard__n{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;color:var(--ink-faint);transition:.25s}
.lcard h3{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--ink);line-height:1.2;transition:.25s}
.lcard p{font-size:13px;color:var(--ink-soft);line-height:1.5;transition:.25s}

/* KEY — определитель */
.key{padding:80px 0}
.key__head{text-align:center;max-width:700px;margin:0 auto 44px}
.key__head .eyebrow{justify-content:center;margin-bottom:18px}
.key__head p{font-size:16.5px;color:var(--ink-soft);margin-top:14px}
.key__panel{background:var(--forest);border-radius:18px;padding:50px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.key__panel::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--forest-line) 1px,transparent 1px),linear-gradient(90deg,var(--forest-line) 1px,transparent 1px);background-size:40px 40px;opacity:.5;pointer-events:none}
.key__panel::after{content:"";position:absolute;top:-80px;right:-80px;width:320px;height:320px;background:radial-gradient(circle,var(--glow),transparent 70%);pointer-events:none}
.key__q{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--moss-bright);text-align:center;margin-bottom:24px;position:relative}
.key__chips{display:flex;flex-wrap:wrap;gap:11px;justify-content:center;max-width:900px;margin:0 auto;position:relative}
.chip{font-family:var(--font-body);font-size:14.5px;color:oklch(90% .02 145);background:var(--forest-2);border:1px solid oklch(40% .05 150);border-radius:999px;padding:11px 20px;cursor:pointer;transition:.2s}
.chip:hover{border-color:var(--moss-bright);color:#fff;transform:translateY(-2px)}
.chip.is-active{background:var(--moss-bright);border-color:var(--moss-bright);color:var(--forest);font-weight:600}
.key__result{margin-top:32px;background:var(--paper-card);border-radius:14px;overflow:hidden;display:none;box-shadow:var(--shadow);position:relative}
.key__result.is-shown{display:block;animation:keyReveal .5s ease-out}
@keyframes keyReveal{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.kres__grid{display:grid;grid-template-columns:118px 1fr auto;gap:28px;align-items:center;padding:28px 32px}
.kres__art{width:108px;height:108px;border:1px solid var(--line);border-radius:10px;display:grid;place-items:center;color:var(--moss);background:var(--paper)}
.kres__art svg{width:72px;height:72px}
.kres__no{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ochre);margin-bottom:8px}
.kres__name{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:8px;line-height:1.1}
.kres__desc{font-size:14px;color:var(--ink-soft);max-width:520px}
.kres__side{text-align:right;display:flex;flex-direction:column;gap:11px;align-items:flex-end}
.kres__price{font-family:var(--font-display);font-size:23px;font-weight:700;color:var(--pine)}
.kres__meta{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint)}

/* HERB / SPEC — карточки программ (используются и в каталоге) */
.herb{padding:80px 0}
.herb__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:42px;flex-wrap:wrap}
.herb__head .eyebrow{margin-bottom:14px}
.herb__head p{font-size:14px;color:var(--ink-faint);font-family:var(--font-mono);letter-spacing:.04em}
.herb__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.spec{position:relative;background:var(--paper-card);border:1px solid var(--line);border-radius:10px;padding:24px 22px 22px;transition:.25s;overflow:hidden;display:flex;flex-direction:column}
.spec::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--moss);transform:scaleY(0);transform-origin:top;transition:.3s}
.spec:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.spec:hover::before{transform:scaleY(1)}
.spec:hover .spec__art{color:var(--moss);transform:scale(1.08) rotate(-3deg)}
.spec__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}
.spec__no{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;color:var(--ink-faint);border:1px solid var(--line);border-radius:4px;padding:4px 8px}
.spec__art{width:50px;height:50px;color:var(--pine);transition:.3s;flex-shrink:0}
.spec__art svg{width:100%;height:100%}
.spec__line{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ochre);margin-bottom:6px}
.spec__dir{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--berry);margin-bottom:8px}
.spec__name{font-family:var(--font-display);font-size:20px;font-weight:600;line-height:1.14;color:var(--ink);margin-bottom:11px}
.spec__out{font-size:13px;color:var(--ink-soft);line-height:1.52;margin-bottom:16px;flex:1}
.spec__data{display:flex;gap:9px;flex-wrap:wrap;font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);padding-top:13px;border-top:1px dashed var(--line-strong)}
.spec__foot{display:flex;justify-content:space-between;align-items:center;margin-top:15px}
.spec__price{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--pine)}
.spec__more{font-family:var(--font-mono);font-size:10.5px;color:var(--moss);letter-spacing:.05em}
.spec details{margin-top:14px;border-top:1px dashed var(--line-strong);padding-top:12px}
.spec summary{cursor:pointer;font-family:var(--font-mono);font-size:11px;color:var(--moss);letter-spacing:.04em;list-style:none}
.spec summary::-webkit-details-marker{display:none}
.spec details[open] summary{margin-bottom:10px}
.spec__mod{margin-bottom:10px}
.spec__mod b{display:block;font-family:var(--font-display);font-size:13.5px;color:var(--ink);font-weight:600}
.spec__mod span{font-size:12px;color:var(--ink-soft);line-height:1.5}
.spec__mod i{display:block;font-style:normal;font-family:var(--font-mono);font-size:10px;color:var(--ochre);text-transform:uppercase;letter-spacing:.08em;margin-top:3px}

/* ECO — экосистема */
.eco{padding:88px 0;background:var(--forest);position:relative;overflow:hidden;margin-top:30px}
.eco::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--forest-line) 1px,transparent 1px),linear-gradient(90deg,var(--forest-line) 1px,transparent 1px);background-size:44px 44px;opacity:.45;pointer-events:none}
.eco .shell{position:relative;z-index:1}
.eco__head{max-width:640px;margin-bottom:48px}
.eco__head .eyebrow{color:var(--moss-bright);margin-bottom:16px}
.eco__head h2{color:var(--paper)}
.eco__head p{font-size:16px;color:oklch(84% .02 145);margin-top:14px}
.eco__enter{margin-top:26px}
.eco__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.ecard{background:oklch(24% .05 156);border:1px solid oklch(38% .05 152);border-radius:14px;padding:30px 28px;display:flex;gap:20px;align-items:flex-start;transition:.25s}
.ecard:hover{border-color:var(--moss-bright);transform:translateY(-3px)}
.ecard__art{width:48px;height:48px;color:var(--moss-bright);flex-shrink:0}
.ecard__art svg{width:100%;height:100%}
.ecard h4{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--paper);margin-bottom:8px}
.ecard p{font-size:14px;color:oklch(82% .02 145);line-height:1.55}

/* GROW — стадии */
.grow{padding:84px 0}
.grow__head{text-align:center;margin-bottom:50px}
.grow__head .eyebrow{justify-content:center;margin-bottom:16px}
.grow__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.grow__steps::before{content:"";position:absolute;top:44px;left:12%;right:12%;height:1px;background:repeating-linear-gradient(90deg,var(--line-strong) 0 8px,transparent 8px 16px)}
.gstep{text-align:center;position:relative}
.gstep__art{width:88px;height:88px;margin:0 auto 18px;color:var(--moss);background:var(--paper);border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;position:relative;z-index:1}
.gstep__art svg{width:50px;height:50px}
.gstep__no{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;color:var(--ochre);margin-bottom:8px}
.gstep h4{font-family:var(--font-display);font-size:19px;font-weight:600;color:var(--ink);margin-bottom:9px}
.gstep p{font-size:13px;color:var(--ink-soft);line-height:1.55}

/* BOUND — границы */
.bound{padding:78px 0}
.bound__card{border:1px solid var(--line);border-radius:18px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.bound__col{padding:44px 42px}
.bound__col--is{background:var(--paper-card)}
.bound__col--not{background:var(--paper-2)}
.bound__k{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:22px}
.bound__col--is .bound__k{color:var(--moss)}
.bound__col--not .bound__k{color:var(--berry)}
.bound__list{list-style:none;display:grid;gap:13px}
.bound__list li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--ink-soft);line-height:1.5}
.bound__col--is li::before{content:"✓";color:var(--moss);font-weight:700;flex-shrink:0}
.bound__col--not li::before{content:"—";color:var(--berry);flex-shrink:0}

/* ENROLL / FORMS */
.enroll{padding:84px 0}
.enroll__card{background:var(--paper-card);border:1px solid var(--line);border-radius:20px;padding:54px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}
.enroll__card::after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;background:radial-gradient(circle,oklch(80% .08 150 / .5),transparent 70%);pointer-events:none}
.enroll h2{margin-bottom:16px}
.enroll p{font-size:16px;color:var(--ink-soft);margin-bottom:22px}
.enroll__list{list-style:none;display:grid;gap:11px}
.enroll__list li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--ink-soft)}
.enroll__list li::before{content:"❧";color:var(--moss);flex-shrink:0}

.form{display:grid;gap:14px;position:relative;z-index:1}
.form-field{display:grid;gap:7px}
.form-field label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.form input,.form select,.form textarea,.form-field input,.form-field select,.form-field textarea{font-family:var(--font-body);font-size:15px;color:var(--ink);background:var(--paper);border:1.5px solid var(--line-strong);border-radius:10px;padding:13px 16px;transition:.2s;width:100%}
.form input:focus,.form select:focus,.form textarea:focus,.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--moss)}
.form textarea,.form-field textarea{resize:vertical;min-height:60px}
.form-check{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--ink-soft);line-height:1.45;cursor:pointer}
.form-check input{width:18px;height:18px;margin-top:2px;accent-color:var(--moss);flex-shrink:0}
.form-check a{color:var(--pine);text-decoration:underline}
.form-submit,.btn.form-submit{margin-top:6px;background:var(--pine);color:var(--paper);border:0;border-radius:999px;padding:15px 30px;font-family:var(--font-body);font-size:16px;font-weight:500;cursor:pointer;transition:.2s;width:100%}
.form-submit:hover{background:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.form-submit:disabled{opacity:.6;cursor:default;transform:none}
.form-note{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);line-height:1.5}
.form-msg{font-size:13.5px;min-height:18px;color:var(--berry);font-family:var(--font-mono)}
.form-msg.is-ok{color:var(--moss)}
.form-done{font-family:var(--font-display);font-size:22px;color:var(--pine)}
.file-field input[type=file]{padding:12px 14px;font-size:13.5px;border-style:dashed}

/* CARD (универсальная для access/payment/learn панелей) */
.panel{max-width:640px;margin:0 auto;background:var(--paper-card);border:1px solid var(--line);border-radius:20px;padding:clamp(28px,5vw,48px);box-shadow:var(--shadow-soft)}
.panel--narrow{max-width:560px}
.panel h1{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,4vw,38px);letter-spacing:-.02em;line-height:1.1;margin-bottom:14px}
.panel .lede{font-size:15px;color:var(--ink-soft);line-height:1.55;margin-bottom:26px}
.panel-info{margin-top:26px;padding:20px 22px;background:var(--paper);border:1px dashed var(--line-strong);border-radius:14px;font-size:13px;color:var(--ink-soft);line-height:1.65}
.panel-info strong{color:var(--ink)}
.panel-help{margin-top:26px;padding-top:22px;border-top:1px dashed var(--line);font-size:13px;color:var(--ink-faint);line-height:1.6}
.panel-help a{color:var(--pine);text-decoration:underline}

/* LEARN — учебный класс */
.learn-wrap{max-width:920px;margin:0 auto}
.learn-head{padding-bottom:26px;border-bottom:1px solid var(--line);margin-bottom:32px}
.learn-head .ctx{display:flex;flex-wrap:wrap;gap:8px 14px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px}
.learn-head h1{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,4vw,42px);line-height:1.12;letter-spacing:-.02em;color:var(--ink)}
.learn-passport{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:26px;padding-top:22px;border-top:1px dashed var(--line-strong)}
.learn-passport dt{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px}
.learn-passport dd{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink)}
.module{padding:24px 0;border-bottom:1px solid var(--line)}
.module h3{font-family:var(--font-display);font-weight:600;font-size:20px;letter-spacing:-.01em;margin-bottom:10px;color:var(--ink)}
.module ul{padding-left:20px;margin-bottom:10px}
.module li{font-size:15px;color:var(--ink-soft);line-height:1.55;margin-bottom:4px}
.module .ctrl{display:inline-block;padding:6px 12px;background:oklch(92% .04 145);color:var(--pine);border-radius:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;margin-top:6px}
.quiz{margin-top:36px;padding:28px;background:var(--paper-card);border:1px solid var(--line);border-radius:16px}
.quiz h2{font-family:var(--font-display);font-weight:600;font-size:22px;margin-bottom:18px;color:var(--ink)}
.quiz-q{padding:18px 0;border-bottom:1px dashed var(--line)}
.quiz-q:last-of-type{border-bottom:0}
.quiz-q .q-text{font-weight:500;margin-bottom:12px}
.quiz-q label{display:block;padding:10px 14px;margin-bottom:8px;background:var(--paper);border:1px solid var(--line);border-radius:10px;cursor:pointer;font-size:14px;transition:.15s}
.quiz-q label:hover{border-color:var(--moss)}
.quiz-q label.is-correct{border-color:var(--moss);background:oklch(94% .05 145)}
.quiz-q label.is-wrong{border-color:var(--berry);background:oklch(95% .04 30)}
.quiz-q label input{margin-right:10px;accent-color:var(--moss)}
.quiz-result{margin-top:18px;padding:14px 18px;border-radius:10px;font-size:14px}
.quiz-result.is-ok{background:oklch(94% .05 145);color:var(--pine)}
.quiz-result.is-bad{background:oklch(95% .04 30);color:var(--berry)}
.resource-block{margin-top:36px;padding:26px;background:var(--forest);border-radius:16px;position:relative;overflow:hidden}
.resource-block h2{font-family:var(--font-display);font-weight:600;font-size:22px;color:var(--paper);margin-bottom:10px}
.resource-block p{font-size:14px;color:oklch(82% .02 145);margin-bottom:16px;line-height:1.55}
.support{margin-top:28px;padding:18px 22px;border:1px dashed var(--line-strong);border-radius:14px;font-size:14px;color:var(--ink-soft);line-height:1.6}
.support a{color:var(--pine);text-decoration:underline}

/* LEGAL — юр-страницы */
.legal{max-width:820px;margin:0 auto;padding:0 0 40px}
.legal h1{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,4vw,44px);line-height:1.08;letter-spacing:-.02em;margin-bottom:10px;color:var(--ink)}
.legal h1 em{font-style:italic;color:var(--moss)}
.legal .legal-meta{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);margin-bottom:32px}
.legal h2{font-family:var(--font-display);font-weight:600;font-size:21px;margin:32px 0 12px;color:var(--pine)}
.legal h3{font-family:var(--font-display);font-weight:600;font-size:17px;margin:22px 0 10px;color:var(--ink)}
.legal p,.legal li{font-size:15px;color:var(--ink-soft);line-height:1.65;margin-bottom:12px}
.legal ul,.legal ol{padding-left:24px;margin-bottom:14px}
.legal a{color:var(--pine);text-decoration:underline}
.legal strong{color:var(--ink)}
.legal em{font-style:italic;color:var(--ink)}
.legal-meta{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.legal .num{color:var(--moss);margin-right:8px;font-weight:700}
.legal .note{padding:16px 20px;background:var(--paper-2);border-left:3px solid var(--moss);border-radius:0 12px 12px 0;margin:18px 0;font-size:14px;color:var(--ink);line-height:1.6}

/* FOOTER */
.ft{border-top:1px solid var(--line);padding:54px 0 34px;background:var(--paper-2)}
.ft__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:34px}
.ft__brand .brand{margin-bottom:14px}
.ft__author{font-family:var(--font-display);font-style:italic;font-size:15px;color:var(--pine);margin-bottom:12px;line-height:1.4}
.ft__brand p{font-size:13px;color:var(--ink-soft);max-width:300px;line-height:1.6}
.ft__col h5{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:15px}
.ft__col a{display:block;font-size:13.5px;color:var(--ink-soft);padding:5px 0;transition:.2s}
.ft__col a:hover{color:var(--pine)}
.ft__legal{border-top:1px solid var(--line);padding-top:22px;font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint);line-height:1.7;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}

/* reveal + прорастание */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s ease-out,transform .55s ease-out}
.reveal.is-visible{opacity:1;transform:none}
.fade-in{opacity:0;transform:translateY(16px);transition:opacity .55s ease-out,transform .55s ease-out}
.fade-in.is-visible{opacity:1;transform:none}
.draw path,.draw circle,.draw ellipse{stroke-dasharray:1;stroke-dashoffset:1}
.draw.is-visible path,.draw.is-visible circle,.draw.is-visible ellipse{animation:draw 1.6s ease forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* адаптив */
@media(max-width:1000px){
  .hero__grid,.path__grid{grid-template-columns:1fr;gap:44px}
  .hero__plate,.path__art{max-width:440px;margin:0 auto}
  .lines__grid{grid-template-columns:repeat(2,1fr)}
  .lcard:nth-child(2n){border-right:0}.lcard{border-bottom:1px solid var(--line)}
  .herb__grid{grid-template-columns:repeat(2,1fr)}
  .eco__grid{grid-template-columns:1fr}
  .grow__steps{grid-template-columns:repeat(2,1fr);gap:40px 24px}.grow__steps::before{display:none}
  .bound__card,.enroll__card{grid-template-columns:1fr}
  .kres__grid{grid-template-columns:1fr;text-align:center;gap:18px}.kres__art{margin:0 auto}.kres__side{align-items:center}.kres__desc{margin:0 auto}
  .learn-passport{grid-template-columns:repeat(2,1fr)}
  .ft__grid{grid-template-columns:1fr 1fr}
  .hd__nav{display:none}.burger{display:flex}
}
@media(max-width:600px){
  .shell{padding:0 20px}.hd__row{padding:11px 20px}
  .lines__grid,.herb__grid,.grow__steps,.ft__grid{grid-template-columns:1fr}
  .lcard{border-right:0}
  .hero{padding:120px 0 50px}.key__panel{padding:30px 20px}
  .hero__facts{grid-template-columns:repeat(2,1fr);gap:22px}
  .bound__col,.enroll__card,.panel{padding:28px 22px}
  .hd__cta .btn--ghost{display:none}
}
