/* ====================================================================
   «Мой Почтовый лес» × «Лесной билет» — демо-лендинг
   Палитра и токены
   ==================================================================== */
:root{
  --blue:#0B3D91;
  --blue-700:#0a3179;
  --blue-100:#e6edf9;
  --green:#2E7D32;
  --green-600:#37923c;
  --green-light:#EAF6EC;
  --green-100:#d8efdc;
  --yellow:#FFD84D;
  --yellow-soft:#fff3cc;
  --white:#FFFFFF;
  --ink:#1F2933;
  --ink-2:#5F6B7A;
  --line:#e4e9ee;
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 2px 8px rgba(31,41,51,.06);
  --shadow:0 12px 34px rgba(11,61,145,.10);
  --shadow-lg:0 24px 60px rgba(11,61,145,.16);
  --maxw:1140px;
  --font:'Manrope','Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:80px;}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--white);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{margin:0;line-height:1.15;font-weight:800;letter-spacing:-.02em;}
p{margin:0;}
ul,ol{margin:0;padding:0;list-style:none;}
a{color:inherit;text-decoration:none;}
img,svg{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- Кнопки ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 26px;border-radius:999px;font-weight:700;font-size:16px;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-sm{padding:10px 18px;font-size:14px;}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 22px rgba(11,61,145,.28);}
.btn-primary:hover{background:var(--blue-700);box-shadow:0 12px 28px rgba(11,61,145,.34);}
.btn-ghost{background:#fff;color:var(--blue);border:2px solid var(--blue-100);}
.btn-ghost:hover{border-color:var(--blue);}
.btn-ghost--light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);}
.btn-ghost--light:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.demo-open-link{width:100%;margin-top:2px;white-space:normal;text-align:center;}

/* ---------- Хедер ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease;
}
.site-header.is-scrolled{box-shadow:var(--shadow-sm);}
.header-inner{display:flex;align-items:center;gap:24px;height:66px;}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:17px;color:var(--ink);}
.brand-mark{display:flex;}
.main-nav{display:flex;gap:26px;margin-left:auto;font-weight:600;font-size:15px;color:var(--ink-2);}
.main-nav a{position:relative;padding:4px 0;transition:color .15s;}
.main-nav a:hover{color:var(--blue);}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--green);transition:width .2s;}
.main-nav a:hover::after{width:100%;}
.header-cta{margin-left:4px;}

/* ---------- Секции ---------- */
.section{padding:88px 0;}
.section--tint{background:var(--green-light);}
.section--dark{background:linear-gradient(160deg,#0B3D91,#0a2f72);color:#fff;}
.section-head{max-width:760px;margin:0 auto 48px;text-align:center;}
.section-head--left{text-align:left;margin:0 0 28px;}
.section-head--light{color:#fff;}
.section-head h2{font-size:clamp(28px,4vw,42px);margin-bottom:14px;}
.h2-sm{font-size:clamp(24px,3vw,32px)!important;}
.section-intro{color:var(--ink-2);font-size:18px;}
.section-intro--light{color:rgba(255,255,255,.82);}
.eyebrow{
  display:inline-block;font-weight:700;font-size:13px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--green);margin-bottom:14px;
  padding:5px 12px;background:var(--green-100);border-radius:999px;
}
.eyebrow--blue{color:var(--blue);background:var(--blue-100);}
.eyebrow--light{color:#fff;background:rgba(255,255,255,.16);}
.eyebrow--star::before{content:"★ ";}

/* ====================================================================
   HERO
   ==================================================================== */
.hero{
  padding-top:64px;padding-bottom:80px;
  background:
    radial-gradient(900px 400px at 85% -10%,var(--green-100),transparent 60%),
    radial-gradient(700px 360px at 0% 10%,var(--blue-100),transparent 55%),
    var(--white);
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.hero-copy h1{font-size:clamp(40px,6vw,68px);margin:10px 0 18px;}
.lead{font-size:20px;color:var(--ink-2);max-width:540px;}
.hero-thesis{display:flex;gap:14px;flex-wrap:wrap;margin:26px 0;}
.thesis-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:12px 16px;font-weight:700;box-shadow:var(--shadow-sm);font-size:15px;
}
.thesis-tag{display:block;font-size:12px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px;font-weight:700;}
.thesis-tag--green{color:var(--green);}
.thesis-tag--yellow{color:#b8860b;}
.advisor-summary{display:flex;flex-wrap:wrap;gap:8px;margin:-10px 0 24px;}
.advisor-summary span{display:inline-flex;align-items:center;gap:6px;background:rgba(11,61,145,.06);color:var(--blue);border:1px solid var(--blue-100);border-radius:999px;padding:8px 12px;font-size:13px;font-weight:800;}
.advisor-summary span::before{content:"✓";color:var(--green);}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px;}
.hero-note{margin-top:18px;font-size:13px;color:var(--ink-2);}

.hero-phone{position:relative;display:flex;justify-content:center;align-items:center;min-width:0;}
.hero-phone-glow{
  position:absolute;inset:auto;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(46,125,50,.22),transparent 70%);
  z-index:0;filter:blur(8px);
}

/* ---------- Телефон (общее) ---------- */
.phone{
  position:relative;z-index:1;width:300px;background:#0f1722;border-radius:42px;
  padding:12px;box-shadow:var(--shadow-lg);border:1px solid #1c2733;
}
.phone-notch{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:120px;height:24px;background:#0f1722;border-radius:0 0 16px 16px;z-index:3;
}
.phone-screen,.phone-body{background:#fff;border-radius:32px;overflow:hidden;}
.phone--static .phone-screen{padding:30px 18px 18px;}
.mini-status{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--blue);font-size:14px;margin-bottom:12px;}
.mini-dot{width:8px;height:8px;border-radius:50%;background:var(--green);}
.mini-forest-svg{width:100%;border-radius:14px;margin-bottom:12px;}
.mini-metrics{font-size:13px;color:var(--ink-2);display:grid;gap:5px;margin-bottom:14px;}
.mini-metrics b{color:var(--ink);}
.mini-btn{background:var(--blue);color:#fff;text-align:center;padding:12px;border-radius:12px;font-weight:700;font-size:14px;}

/* ====================================================================
   Карточки / списки
   ==================================================================== */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.card h3{font-size:20px;margin-bottom:14px;}
.card--muted{background:#f7f9fb;}
.card--accent-green{border-color:var(--green-100);box-shadow:0 12px 30px rgba(46,125,50,.10);}
.card--accent-blue{border-color:var(--blue-100);box-shadow:0 12px 30px rgba(11,61,145,.10);}
.card-badge{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:999px;margin-bottom:14px;}
.card-badge--gray{background:#eef1f4;color:var(--ink-2);}
.card-badge--green{background:var(--green);color:#fff;}
.card-badge--blue{background:var(--blue);color:#fff;}

.ticks{display:grid;gap:9px;}
.ticks li{position:relative;padding-left:28px;color:var(--ink);font-size:15px;}
.ticks li::before{position:absolute;left:0;top:0;font-weight:700;}
.ticks--green li::before{content:"✓";color:var(--green);}
.ticks--blue li::before{content:"✓";color:var(--blue);}
.ticks--amber li::before{content:"✓";color:#b8860b;}
.ticks--neutral li{color:var(--ink-2);}
.ticks--neutral li::before{content:"–";color:var(--ink-2);}
.ticks--light li{color:rgba(255,255,255,.92);}
.ticks--light li::before{content:"✓";color:var(--yellow);}

/* ---------- Гибридная модель ---------- */
.hybrid-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:stretch;}
.hybrid-card{border-radius:var(--radius);padding:30px;background:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--line);}
.hybrid-card--green{border-top:5px solid var(--green);}
.hybrid-card--yellow{border-top:5px solid var(--yellow);}
.hybrid-icon{font-size:38px;margin-bottom:10px;}
.hybrid-card h3{font-size:21px;margin-bottom:16px;}
.hybrid-plus{align-self:center;font-size:40px;font-weight:800;color:var(--ink-2);}
.pull-quote{
  max-width:780px;margin:40px auto 0;text-align:center;font-size:21px;font-weight:600;
  color:var(--blue);line-height:1.45;padding:24px 28px;background:#fff;border-radius:var(--radius);
  border-left:5px solid var(--green);box-shadow:var(--shadow-sm);
}

/* ---------- Шаги ---------- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;counter-reset:s;}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;position:relative;box-shadow:var(--shadow-sm);transition:transform .2s;}
.step:hover{transform:translateY(-4px);}
.step-num{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--blue);color:#fff;font-weight:800;margin-bottom:14px;}
.step h3{font-size:17px;margin-bottom:8px;}
.step p{font-size:14px;color:var(--ink-2);}

/* ====================================================================
   ДЕМО ПРИЛОЖЕНИЯ (интерактивный телефон)
   ==================================================================== */
.app-demo{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:start;max-width:1000px;margin:0 auto;}
.demo-controls{display:grid;gap:28px;padding-top:10px;}
.control-group{display:grid;gap:12px;}
.control-label{font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.65);}
.screen-tabs{display:flex;flex-wrap:wrap;gap:8px;}
.screen-tab{
  padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.10);color:#fff;
  font-weight:600;font-size:14px;transition:background .15s,color .15s;
}
.screen-tab:hover{background:rgba(255,255,255,.18);}
.screen-tab.is-active{background:var(--yellow);color:var(--ink);}
.interface-demo{max-width:1060px;}
.interface-copy{display:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:22px;box-shadow:0 18px 36px rgba(0,0,0,.10);}
.interface-copy.is-active{display:block;animation:screenIn .25s ease;}
.interface-copy h3{font-size:26px;color:#fff;margin-bottom:10px;}
.interface-copy p{color:rgba(255,255,255,.78);margin-bottom:16px;}
.interface-demo .demo-hint{margin-top:-8px;}

.toggle{display:flex;align-items:center;gap:12px;cursor:pointer;}
.toggle input{position:absolute;opacity:0;pointer-events:none;}
.toggle-track{width:46px;height:26px;border-radius:999px;background:rgba(255,255,255,.22);position:relative;flex-shrink:0;transition:background .2s;}
.toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s;}
.toggle input:checked + .toggle-track{background:var(--green-600);}
.toggle input:checked + .toggle-track .toggle-thumb{transform:translateX(20px);}
.toggle input:focus-visible + .toggle-track{outline:2px solid var(--yellow);outline-offset:2px;}
.toggle-text b{display:block;font-size:15px;}
.toggle-text small{color:rgba(255,255,255,.6);font-size:12px;}
.demo-hint{font-size:14px;color:rgba(255,255,255,.7);background:rgba(255,255,255,.07);border-radius:12px;padding:14px 16px;border-left:3px solid var(--yellow);}

.demo-phone-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;}
.phone--live{width:320px;max-width:100%;}
.phone--prototype{width:min(390px,100vw - 28px);}
.phone-statusbar{display:flex;justify-content:space-between;padding:30px 22px 6px;font-size:12px;font-weight:700;color:var(--ink);}
.phone-appbar{display:flex;align-items:center;gap:10px;padding:6px 18px 12px;border-bottom:1px solid var(--line);}
.appbar-back{font-size:24px;color:var(--blue);line-height:1;}
.appbar-title{font-weight:800;font-size:15px;flex:1;}
.appbar-status{font-size:12px;font-weight:700;color:var(--green);background:var(--green-100);padding:4px 10px;border-radius:999px;transition:.2s;}
.phone-body{height:min(520px,72vh);overflow-y:auto;padding:18px;position:relative;border-radius:0 0 32px 32px;scrollbar-width:thin;overscroll-behavior:contain;}
.phone-body::-webkit-scrollbar{width:5px;}
.phone-body::-webkit-scrollbar-thumb{background:#d4dbe2;border-radius:4px;}

.screen{display:none;animation:screenIn .35s ease;}
.screen.is-active{display:block;}
@keyframes screenIn{from{opacity:0;transform:translateX(10px);}to{opacity:1;transform:none;}}
.screen-title{font-size:18px;margin-bottom:6px;}
.screen-sub{font-size:14px;color:var(--ink-2);margin-bottom:14px;}

/* лес на главном */
.forest-stage{position:relative;margin-bottom:16px;}
.forest-svg{width:100%;}
.level-pill{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.9);color:var(--green);font-weight:700;font-size:12px;padding:5px 11px;border-radius:999px;box-shadow:var(--shadow-sm);}
.main-tree{transform-origin:129px 140px;transition:transform .6s cubic-bezier(.34,1.56,.64,1);}
.main-tree .crown circle{transition:r .5s ease;}

.forest-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.metric{background:var(--green-light);border-radius:12px;padding:12px;text-align:center;}
.metric-val{display:block;font-size:26px;font-weight:800;color:var(--green);line-height:1;}
.metric-cap{font-size:11px;color:var(--ink-2);}

.goal{background:#f7f9fb;border-radius:12px;padding:14px;margin-bottom:14px;}
.goal-top{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-2);margin-bottom:8px;}
.goal-top b{color:var(--ink);}
.bar{height:10px;border-radius:999px;background:#e1e7ec;overflow:hidden;}
.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--green-600));transition:width .9s cubic-bezier(.22,1,.36,1);}
.goal-region{font-size:12px;color:var(--ink-2);margin-top:8px;}

.app-btn{display:block;width:100%;padding:14px;border-radius:14px;font-weight:700;font-size:15px;text-align:center;transition:transform .12s,filter .15s,background .15s;}
.app-btn:active{transform:scale(.98);}
.app-btn--primary{background:var(--blue);color:#fff;}
.app-btn--primary:hover{background:var(--blue-700);}
.app-btn--soft{background:var(--green-light);color:var(--green);font-size:13px;padding:12px;}
.app-btn--soft:hover{background:var(--green-100);}
.app-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;}
.app-links{display:flex;flex-wrap:wrap;gap:6px 16px;margin-top:14px;justify-content:center;}
.app-links--center{justify-content:center;}
.app-links button{color:var(--blue);font-size:13px;font-weight:600;text-decoration:underline;text-underline-offset:3px;}

/* экран забота */
.care-svg{width:62%;margin:6px auto 0;}
.care-tree .main-tree,.care-tree{transition:transform .5s;}
.care-svg .crown circle{transform-origin:100px 70px;transition:transform .5s cubic-bezier(.34,1.56,.64,1);}
.care-svg.is-watered .crown circle{transform:scale(1.06);}
.drops{opacity:0;}
.drops.show{animation:drop .9s ease;}
@keyframes drop{0%{opacity:1;transform:translateY(0);}100%{opacity:0;transform:translateY(26px);}}
.care-result{background:var(--green-light);border-radius:12px;padding:14px;font-size:14px;text-align:center;margin:14px 0;min-height:64px;display:flex;align-items:center;justify-content:center;}
.care-result.is-active{background:var(--green-100);font-weight:600;color:var(--green);}
.care-note{font-size:12px;color:var(--ink-2);text-align:center;margin-top:12px;}

/* экран подписка */
.keeper-banner{background:var(--green-100);color:var(--green);border-radius:12px;padding:12px 14px;font-size:13px;margin-bottom:14px;border-left:3px solid var(--green);}
.plans{display:grid;gap:10px;margin-bottom:14px;}
.plan{text-align:left;border:2px solid var(--line);border-radius:14px;padding:14px;position:relative;transition:border-color .15s,box-shadow .15s,transform .12s;background:#fff;}
.plan:hover{border-color:var(--green-100);}
.plan.is-selected{border-color:var(--green);box-shadow:0 8px 20px rgba(46,125,50,.16);}
.plan--reco{border-color:var(--green);}
.plan-flag{position:absolute;top:-10px;right:14px;background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;}
.plan-price{font-size:20px;font-weight:800;color:var(--ink);}
.plan-price small{font-size:13px;color:var(--ink-2);font-weight:600;}
.plan-name{display:block;font-weight:700;color:var(--green);margin:2px 0 4px;}
.plan-feat{font-size:12px;color:var(--ink-2);}

/* экран билет */
.ticket-head{text-align:center;margin-bottom:12px;}
.season-chip{display:inline-block;background:var(--yellow-soft);color:#9a7400;font-weight:700;font-size:12px;padding:4px 12px;border-radius:999px;margin-bottom:8px;}
.ticket-count{text-align:center;background:linear-gradient(135deg,#fff7da,#fff);border:1px dashed var(--yellow);border-radius:16px;padding:18px;margin-bottom:14px;}
.ticket-count-num{display:block;font-size:44px;font-weight:800;color:#b8860b;line-height:1;}
.ticket-count-cap{font-size:13px;color:var(--ink-2);}
.ticket-meta{font-size:13px;color:var(--ink);display:grid;gap:6px;margin-bottom:14px;}
.ticket-meta b{color:var(--blue);}
.ticket-prizes{display:grid;gap:8px;font-size:13px;margin-bottom:14px;}
.ticket-prizes li{background:#f7f9fb;border-radius:10px;padding:10px 12px;}
.ticket-disclaimer{font-size:12px;color:var(--green);text-align:center;margin-top:12px;font-weight:600;}

/* экран призов за баллы */
.points-card{background:linear-gradient(135deg,var(--blue-100),#fff);border:1px solid var(--blue-100);border-radius:16px;padding:16px;margin-bottom:14px;text-align:center;}
.points-card span{display:block;font-size:12px;color:var(--ink-2);font-weight:700;text-transform:uppercase;letter-spacing:.05em;}
.points-card b{display:block;font-size:40px;line-height:1;color:var(--blue);margin:4px 0;}
.points-card small{display:block;font-size:12px;color:var(--ink-2);line-height:1.4;}
.prize-wheel{position:relative;display:grid;grid-template-columns:repeat(2,1fr);gap:8px;background:var(--yellow-soft);border:2px solid var(--yellow);border-radius:50%;width:220px;height:220px;margin:10px auto 16px;padding:28px;align-content:center;justify-content:center;transition:transform .9s cubic-bezier(.22,1,.36,1);box-shadow:inset 0 0 0 10px rgba(255,255,255,.45);}
.prize-wheel::after{content:"";position:absolute;inset:82px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 8px #fff;}
.prize-wheel span{position:relative;z-index:1;background:#fff;border-radius:999px;padding:6px 8px;text-align:center;font-size:11px;font-weight:800;color:var(--blue);box-shadow:var(--shadow-sm);}
.prize-wheel.is-spinning{transform:rotate(720deg);}

/* экран отчёт */
.report-photo{margin-bottom:14px;}
.report-svg{width:100%;border-radius:14px;}
.report-list{display:grid;gap:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:12px;}
.report-list li{display:flex;justify-content:space-between;gap:12px;padding:11px 14px;font-size:13px;border-bottom:1px solid var(--line);}
.report-list li:last-child{border-bottom:none;}
.report-list li span{color:var(--ink-2);}
.report-list li b{text-align:right;color:var(--ink);}
.status-tag{color:var(--green)!important;}
.report-note{font-size:12px;color:var(--ink-2);margin-bottom:12px;background:var(--green-light);padding:10px 12px;border-radius:10px;}

/* тост */
.phone-toast{
  position:absolute;left:50%;bottom:20px;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;padding:12px 18px;border-radius:12px;font-size:13px;font-weight:600;
  max-width:84%;text-align:center;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:5;box-shadow:var(--shadow);
}
.phone-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.phone-caption{font-size:12px;color:rgba(255,255,255,.6);}
.section--dark .phone-caption{color:rgba(255,255,255,.6);}
#app .phone-caption{color:rgba(255,255,255,.55);}

.interface-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;align-items:stretch;}
.interface-card{position:relative;overflow:hidden;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:22px;box-shadow:0 18px 42px rgba(0,0,0,.16);}
.interface-card::after{content:"";position:absolute;inset:auto -35px -48px auto;width:120px;height:120px;border-radius:50%;background:rgba(255,216,77,.12);}
.interface-icon{display:grid;place-items:center;width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.12);font-size:24px;margin-bottom:14px;}
.interface-card h3{color:#fff;font-size:21px;margin-bottom:10px;}
.interface-card p{color:rgba(255,255,255,.74);font-size:14px;margin-bottom:16px;}
.interface-card .ticks li{font-size:13px;}
.interface-card--forest{border-color:rgba(111,205,118,.34);}
.interface-card--ticket{border-color:rgba(255,216,77,.34);}
.interface-card--prizes{background:linear-gradient(180deg,rgba(255,216,77,.16),rgba(255,255,255,.08));}
.interface-card--report{border-color:rgba(138,187,255,.35);}
.interface-prizes-note{margin:24px auto 0;max-width:900px;border:1px solid rgba(255,216,77,.34);background:rgba(255,216,77,.10);color:rgba(255,255,255,.84);border-radius:20px;padding:18px 22px;text-align:center;font-size:15px;}
.interface-prizes-note b{color:#fff;}

/* ---------- Ритуал ---------- */
.ritual{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:820px;margin:0 auto;}
.ritual li{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 18px;font-weight:600;box-shadow:var(--shadow-sm);}
.ritual li span{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--green-light);color:var(--green);font-weight:800;flex-shrink:0;}
.quote-card{max-width:560px;margin:32px auto 0;background:var(--green-light);border-radius:var(--radius);padding:22px 26px;text-align:center;font-size:17px;font-weight:600;color:var(--green);border:1px solid var(--green-100);}
.quote-card--sm{font-size:15px;text-align:left;margin:16px 0 0;}

/* ---------- Донаты ---------- */
.donate-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start;}
.donate-options{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.donate-opt{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:20px;box-shadow:var(--shadow-sm);transition:transform .2s,border-color .2s;}
.donate-opt:hover{transform:translateY(-3px);border-color:var(--green-100);}
.donate-opt b{display:block;font-size:24px;color:var(--blue);}
.donate-opt span{font-size:13px;color:var(--ink-2);}
.donate-opt--custom b{color:var(--green);font-size:18px;}
.donate-after h3{font-size:20px;margin-bottom:14px;}

/* ---------- Подписка ---------- */
.sub-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:36px;}
.sub-plan{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;}
.sub-plan:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.sub-plan--reco{border:2px solid var(--green);box-shadow:0 16px 40px rgba(46,125,50,.16);transform:scale(1.03);}
.sub-plan--reco:hover{transform:scale(1.03) translateY(-5px);}
.sub-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--green);color:#fff;font-size:12px;font-weight:700;padding:5px 14px;border-radius:999px;white-space:nowrap;}
.sub-price{font-size:34px;font-weight:800;color:var(--blue);margin-bottom:4px;}
.sub-price small{font-size:16px;color:var(--ink-2);font-weight:600;}
.sub-plan h3{font-size:20px;color:var(--green);margin-bottom:16px;}
.sub-benefits{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);}
.sub-benefits h3{font-size:20px;margin-bottom:18px;text-align:center;}
.benefit-chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}
.benefit-chips span{background:var(--green-light);color:var(--green);font-weight:600;font-size:14px;padding:10px 16px;border-radius:999px;}

/* ---------- Марки ---------- */
.stamps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.stamp{
  position:relative;background:#fff;border-radius:14px;padding:14px;box-shadow:var(--shadow-sm);
  transition:transform .25s,box-shadow .25s;
  /* зубчатый край марки */
  -webkit-mask:radial-gradient(circle 6px at 6px 6px,transparent 98%,#000) -6px -6px;
}
.stamp{
  background-image:
    radial-gradient(circle 5px at center,transparent 4px,#fff 4px);
}
.stamp-inner{border:2px dashed var(--line);border-radius:10px;overflow:hidden;}
.stamp:hover{transform:translateY(-6px) rotate(-1deg);box-shadow:var(--shadow);}
.stamp svg{width:100%;}
.stamp-cap{padding:12px 6px 4px;}
.stamp-region{font-weight:800;font-size:15px;}
.stamp-desc{font-size:12px;color:var(--ink-2);}
.stamp-denom{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.85);border-radius:8px;padding:2px 7px;font-size:11px;font-weight:800;color:var(--blue);}
.stamps-note{text-align:center;margin-top:24px;color:var(--ink-2);font-size:14px;}

/* ---------- Сезоны / Лесной билет ---------- */
.seasons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:28px;}
.seasons span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 18px;font-weight:600;font-size:14px;box-shadow:var(--shadow-sm);}
.legal-note{display:flex;gap:16px;background:var(--blue-100);border-radius:var(--radius);padding:22px 26px;max-width:860px;margin:0 auto 36px;align-items:flex-start;}
.legal-ico{font-size:26px;flex-shrink:0;}
.legal-note p{font-size:15px;color:var(--blue-700);}
.ticket-rules{max-width:720px;margin:0 auto;}
.ticket-rules h3{font-size:20px;margin-bottom:16px;text-align:center;}
.rules-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.rules-table th,.rules-table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);}
.rules-table th{background:var(--green-light);font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--green);}
.rules-table td:last-child,.rules-table th:last-child{text-align:right;font-weight:800;color:var(--blue);}
.rules-table tr:last-child td{border-bottom:none;}
.rules-limit{font-size:13px;color:var(--ink-2);margin-top:14px;text-align:center;}

/* ---------- Призы ---------- */
.prize-main{display:flex;gap:18px;align-items:center;background:linear-gradient(135deg,var(--blue),var(--blue-700));color:#fff;border-radius:var(--radius);padding:26px 30px;margin-bottom:32px;box-shadow:var(--shadow);}
.prize-main-ico{font-size:46px;}
.prize-main-label{display:block;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--yellow);font-weight:700;margin-bottom:4px;}
.prize-main p{font-size:18px;font-weight:600;}
.prize-limit{text-align:center;margin-top:26px;font-size:14px;color:var(--ink-2);max-width:680px;margin-left:auto;margin-right:auto;}
.prize-showcase{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center;margin-top:34px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);}
.prize-showcase-copy h3{font-size:24px;margin-bottom:12px;}
.prize-showcase-copy p{color:var(--ink-2);margin-bottom:16px;}
.prize-screen-mock{position:relative;overflow:hidden;border-radius:30px;background:linear-gradient(180deg,#f4f8f4,#eef6ef);border:8px solid #122033;color:var(--ink);box-shadow:var(--shadow-lg);padding:12px;max-width:330px;margin-inline:auto;}
.mock-status{display:flex;justify-content:space-between;font-size:11px;font-weight:900;color:#2b3440;padding:4px 8px 9px;}
.mock-head{background:#fff;border-radius:22px;padding:16px;margin-bottom:10px;box-shadow:var(--shadow-sm);}
.mock-head h4{font-size:24px;margin:3px 0 6px;}
.mock-head p{font-size:12px;color:var(--ink-2);line-height:1.35;}
.mock-balance{display:grid;gap:2px;background:#fff;border:1px solid #e3ebe4;border-radius:20px;padding:14px;margin-bottom:10px;box-shadow:var(--shadow-sm);}
.mock-balance span{font-size:11px;color:var(--ink-2);font-weight:900;text-transform:uppercase;letter-spacing:.05em;}.mock-balance b{font-size:20px;color:var(--blue);}.mock-balance small{font-size:11px;color:var(--ink-2);line-height:1.35;}
.mock-prize-lane{position:relative;height:282px;overflow:hidden;border-radius:24px;background:linear-gradient(180deg,#fff8d8,#e9f6ec);border:1px solid #e7dfb8;padding:48px 12px 12px;margin-bottom:12px;}
.mock-pointer{position:absolute;left:18px;right:18px;top:122px;z-index:2;background:rgba(11,61,145,.92);color:#fff;border-radius:999px;padding:8px 12px;text-align:center;font-size:12px;font-weight:900;box-shadow:0 10px 24px rgba(11,61,145,.22);}
.mock-prize-item{height:52px;display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e3ebe4;border-radius:17px;padding:8px 10px;margin-bottom:8px;font-size:11px;font-weight:900;box-shadow:var(--shadow-sm);}
.mock-prize-item span{display:grid;place-items:center;width:34px;height:34px;border-radius:13px;background:var(--yellow-soft);font-size:21px;flex-shrink:0;}.mock-prize-item.is-focus{outline:3px solid var(--yellow);transform:scale(1.02);}
.mock-cta{width:100%;min-height:48px;border-radius:17px;background:var(--blue);color:#fff;font-weight:900;font-size:13px;box-shadow:0 14px 30px rgba(11,61,145,.28);}

/* ---------- Доверие ---------- */
.trust-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start;}
.trust-honesty{margin-top:20px;background:var(--yellow-soft);border-radius:12px;padding:16px 18px;font-size:14px;color:#7a5c00;}
.trust-report{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);}
.status-flow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;}
.status-step{font-size:12px;font-weight:600;padding:7px 12px;border-radius:999px;background:#eef1f4;color:var(--ink-2);position:relative;}
.status-step.is-done{background:var(--green-100);color:var(--green);}
.status-step.is-active{background:var(--green);color:#fff;}

/* ---------- Сценарии ---------- */
.scenario{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;}
.scenario:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.scenario--accent{border-top:5px solid var(--green);}
.scenario-num{font-size:14px;font-weight:800;color:var(--green);letter-spacing:.1em;}
.scenario h3{font-size:20px;margin:6px 0 4px;}
.scenario-tag{color:var(--ink-2);font-style:italic;margin-bottom:14px;}
.scenario-steps{counter-reset:ss;display:grid;gap:8px;margin-bottom:16px;}
.scenario-steps li{counter-increment:ss;position:relative;padding-left:28px;font-size:14px;color:var(--ink);}
.scenario-steps li::before{content:counter(ss);position:absolute;left:0;top:0;width:20px;height:20px;border-radius:50%;background:var(--green-light);color:var(--green);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;}
.scenario-result{font-size:14px;font-weight:600;color:var(--blue);background:var(--blue-100);border-radius:10px;padding:12px 14px;}

/* ---------- Польза ---------- */
.benefits-cols{display:grid;grid-template-columns:1fr 1fr;gap:48px;}
.benefit-rows{display:grid;gap:14px;}
.benefit-rows li{background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow-sm);}
.benefit-rows--green li{border-left-color:var(--green);}
.benefit-rows b{display:block;font-size:16px;margin-bottom:4px;}
.benefit-rows span{font-size:14px;color:var(--ink-2);}

/* ---------- Финал ---------- */
.final{background:linear-gradient(160deg,#2E7D32,#1f5a23);color:#fff;text-align:center;}
.final-inner{max-width:760px;margin:0 auto;}
.final h2{font-size:clamp(30px,4.5vw,46px);margin:12px 0 18px;}
.final-text{font-size:19px;color:rgba(255,255,255,.9);margin-bottom:30px;}
.final-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.final .btn-primary{background:#fff;color:var(--green);}
.final .btn-primary:hover{background:var(--yellow);color:var(--ink);}

/* ---------- Отдельная страница мобильного прототипа ---------- */
.prototype-page{min-height:100vh;background:linear-gradient(160deg,#0B3D91,#0a2f72 48%,#2E7D32);color:#fff;}
.prototype-shell{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:18px;}
.prototype-topbar{width:min(960px,100%);display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px;font-size:14px;color:rgba(255,255,255,.78);}
.prototype-topbar a{font-weight:800;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px 14px;}
.prototype-brief{width:min(960px,100%);display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:end;margin-bottom:18px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:20px 22px;box-shadow:0 18px 40px rgba(0,0,0,.14);backdrop-filter:blur(10px);}
.prototype-kicker{display:inline-block;margin-bottom:8px;color:var(--yellow);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;}
.prototype-brief h1{font-size:clamp(24px,4vw,36px);margin-bottom:8px;}
.prototype-brief p{max-width:650px;color:rgba(255,255,255,.78);font-size:15px;}
.prototype-brief-tags{display:flex;flex-direction:column;gap:8px;align-items:flex-end;}
.prototype-brief-tags span{white-space:nowrap;border-radius:999px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.18);padding:8px 12px;font-size:13px;font-weight:800;}
.prototype-stage{width:min(960px,100%);display:grid;grid-template-columns:240px minmax(320px,390px);gap:22px;justify-content:center;align-items:start;}
.prototype-controls,.prototype-toggles{display:grid;gap:10px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:14px;backdrop-filter:blur(10px);}
.prototype-toggles{margin-top:14px;}
.prototype-stage .screen-tab{width:100%;justify-content:center;}
.prototype-stage .phone{justify-self:center;}

/* ---------- Production-like прототип отдельной страницы ---------- */
html.rp-prototype-document{min-height:100%;background:#f4f7f4;}
html.rp-prototype-document body{min-height:100%;width:100%;}
.rp-prototype-page{min-height:100%;background:#f4f7f4;color:var(--ink);overflow-x:hidden;}
.rp-prototype-shell{min-height:100dvh;width:100%;display:block;padding:0;background:#f4f7f4;}
.rp-prototype-note{color:#fff;max-width:420px;}
.rp-back-link{display:inline-flex;margin-bottom:26px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);font-weight:800;}
.rp-kicker{display:inline-block;color:var(--yellow);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;}
.rp-prototype-note h1{font-size:clamp(32px,5vw,54px);margin-bottom:14px;}
.rp-prototype-note p{font-size:18px;color:rgba(255,255,255,.82);margin-bottom:22px;}
.rp-note-grid{display:grid;gap:10px;grid-template-columns:1fr 1fr;}
.rp-note-grid span{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:12px 14px;font-weight:800;}
.rp-device{display:flex;justify-content:center;}
.rp-app-screen{position:relative;width:100%;min-height:100dvh;background:#f4f7f4;padding-bottom:calc(92px + env(safe-area-inset-bottom));}
.rp-phone-frame{position:relative;width:min(430px,100%);height:min(880px,calc(100vh - 48px));min-height:720px;background:#f4f7f4;border:10px solid #13233b;border-radius:42px;box-shadow:0 30px 80px rgba(9,30,66,.25),inset 0 0 0 1px rgba(255,255,255,.55);overflow:hidden;}
.rp-statusbar{height:34px;display:flex;justify-content:space-between;align-items:end;padding:0 22px 6px;background:#fff;font-size:12px;font-weight:900;}
.rp-app-header{height:62px;display:flex;align-items:center;gap:12px;padding:10px 16px;background:#fff;border-bottom:1px solid #e6ece7;}
.rp-app-header div{flex:1;display:grid;gap:2px;}.rp-app-header b{font-size:17px;}.rp-app-header span{font-size:12px;color:var(--green);font-weight:800;}
.rp-icon-btn{width:34px;height:34px;border-radius:12px;background:var(--blue-100);color:var(--blue);font-weight:900;font-size:20px;}
.rp-app-scroll{height:calc(100% - 170px);overflow-y:auto;padding:14px 14px 22px;scrollbar-width:none;overscroll-behavior:contain;}.rp-app-scroll::-webkit-scrollbar{display:none;}
.rp-app-screen .rp-app-scroll{height:auto;overflow:visible;padding:14px clamp(12px,3vw,28px) 22px;scrollbar-width:auto;overscroll-behavior:auto;}
.rp-app-screen .rp-statusbar,.rp-app-screen .rp-app-header,.rp-app-screen .rp-app-scroll{width:100%;max-width:760px;margin-inline:auto;}
.rp-view{display:none;animation:rpView .28s ease;}.rp-view.is-active{display:block;}@keyframes rpView{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.rp-hero-card,.rp-card{background:#fff;border:1px solid #e3ebe4;border-radius:24px;box-shadow:0 10px 26px rgba(30,80,50,.08);padding:16px;margin-bottom:12px;}
.rp-hero-card{background:linear-gradient(180deg,#fff,#eef8ef);overflow:hidden;}.rp-hero-top{display:flex;justify-content:space-between;gap:8px;margin-bottom:10px;}
.rp-pill{display:inline-flex;align-items:center;border-radius:999px;background:#e9f5eb;color:var(--green);padding:6px 10px;font-size:11px;font-weight:900;}.rp-pill-blue{background:var(--blue-100);color:var(--blue);}.rp-pill-yellow{background:var(--yellow-soft);color:#8a6800;}
.rp-forest-visual{position:relative;height:190px;border-radius:22px;background:linear-gradient(180deg,#dff2ff 0%,#eaf6ec 62%,#cfead2 63%);overflow:hidden;margin-bottom:14px;}.rp-sun{position:absolute;right:34px;top:24px;width:38px;height:38px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 12px rgba(255,216,77,.24);}.rp-cloud{position:absolute;width:80px;height:22px;border-radius:999px;background:rgba(255,255,255,.75);}.rp-cloud::before{content:"";position:absolute;left:18px;top:-13px;width:28px;height:28px;border-radius:50%;background:inherit;}.rp-cloud-one{left:24px;top:38px;animation:rpDrift 7s ease-in-out infinite;}.rp-cloud-two{right:70px;top:72px;transform:scale(.75);animation:rpDrift 8s ease-in-out infinite reverse;}@keyframes rpDrift{50%{transform:translateX(12px)}}
.rp-ground{position:absolute;left:-8%;right:-8%;bottom:-16px;height:64px;border-radius:50% 50% 0 0;background:#bfe1c2;}.rp-tree{position:absolute;z-index:2;bottom:34px;width:84px;height:112px;left:50%;margin-left:-42px;transform-origin:50% 100%;transition:transform .55s cubic-bezier(.2,1.4,.4,1);}.rp-tree::after{content:"";position:absolute;left:37px;bottom:0;width:11px;height:54px;border-radius:8px;background:#8a5d3c;}.rp-tree span,.rp-tree span::before,.rp-tree span::after{position:absolute;display:block;border-radius:50%;background:var(--green);content:"";}.rp-tree span{left:18px;top:9px;width:50px;height:50px;box-shadow:0 30px 0 7px #31923a;}.rp-tree span::before{left:-15px;top:34px;width:44px;height:44px;background:#3baa43;}.rp-tree span::after{right:-15px;top:34px;width:44px;height:44px;background:#43ad4d;}.rp-tree-small{width:52px;height:76px;bottom:30px;transform:scale(.72);}.rp-tree-small::after{left:22px;height:34px;width:8px;}.rp-tree-small span{left:10px;width:34px;height:34px;}.rp-tree-a{left:22%;}.rp-tree-b{left:78%;transform:scale(.62);}.rp-forest-visual.is-growing .rp-tree-main{transform:scale(1.1);filter:drop-shadow(0 0 18px rgba(46,125,50,.35));}.rp-float-score{position:absolute;left:50%;top:76px;z-index:4;opacity:0;transform:translate(-50%,16px);background:#fff;color:var(--green);font-weight:900;border-radius:999px;padding:6px 12px;box-shadow:var(--shadow);}.rp-float-score.show{animation:rpFloat 1s ease;}@keyframes rpFloat{0%{opacity:0;transform:translate(-50%,16px)}25%,75%{opacity:1}100%{opacity:0;transform:translate(-50%,-34px)}}
.rp-hero-card h2{font-size:24px;margin-bottom:6px;}.rp-hero-card p,.rp-card p{font-size:13px;color:var(--ink-2);}.rp-balance-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;}.rp-balance-row div{background:#fff;border:1px solid #e3ebe4;border-radius:18px;padding:12px;text-align:center;box-shadow:0 8px 18px rgba(30,80,50,.06);}.rp-balance-row b{display:block;font-size:25px;color:var(--blue);line-height:1;}.rp-balance-row span{font-size:11px;color:var(--ink-2);font-weight:800;}
.rp-card-title{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px;font-size:13px;color:var(--ink-2);}.rp-card-title b{color:var(--ink);}.rp-progress{height:11px;background:#e3e9e5;border-radius:999px;overflow:hidden;margin-bottom:8px;}.rp-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--green),#6fbd54);transition:width .7s ease;}.rp-card small,.rp-legal{font-size:11px;color:var(--ink-2);line-height:1.45;}.rp-action-stack{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;}.rp-action-stack .rp-btn-primary{grid-column:1/-1;}.rp-btn{min-height:46px;border-radius:16px;font-weight:900;font-size:14px;transition:transform .12s,box-shadow .2s,background .2s;}.rp-btn:active{transform:scale(.98);}.rp-btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 22px rgba(11,61,145,.22);}.rp-btn-soft{background:#e9f5eb;color:var(--green);}.rp-btn-subscribe{background:linear-gradient(135deg,var(--yellow),#ffe985);color:#4c3a00;}.rp-inline-link{color:var(--blue);font-weight:900;text-decoration:underline;text-underline-offset:3px;margin-top:8px;}.rp-sub-card h3{margin:8px 0 6px;font-size:18px;}
.rp-screen-head{margin:4px 2px 14px;}.rp-screen-head h2{font-size:25px;margin-bottom:6px;}.rp-screen-head p{font-size:13px;color:var(--ink-2);}.rp-task-list{display:grid;gap:10px;}.rp-task{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid #e3ebe4;border-radius:20px;padding:14px;box-shadow:0 8px 20px rgba(30,80,50,.07);}.rp-task b{display:block;font-size:14px;}.rp-task span{font-size:12px;color:var(--green);font-weight:900;}.rp-task button,.rp-task a{border-radius:13px;background:var(--blue);color:#fff;padding:10px 12px;font-weight:900;white-space:nowrap;font-size:12px;}.rp-task.is-done{background:#edf8ef;border-color:#c9e7cd;}.rp-task.is-done button,.rp-task.is-done a{background:#dbe9de;color:var(--green);}.rp-task-featured{border-color:var(--yellow);background:#fffaf0;}
.rp-ticket-topline{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px;}.rp-ticket-balance{border-radius:18px;background:linear-gradient(180deg,#fff,#f4f8ff);border:1px solid #dfe8f5;padding:10px;text-align:center;box-shadow:0 8px 18px rgba(11,61,145,.07);}.rp-ticket-balance span{display:block;font-size:10px;color:var(--ink-2);font-weight:900;text-transform:uppercase;}.rp-ticket-balance b{display:block;font-size:27px;color:var(--blue);line-height:1;}.rp-ticket-balance small{font-size:10px;color:var(--ink-2);font-weight:800;}.rp-grand-prize{display:grid;grid-template-columns:112px 1fr;gap:13px;align-items:center;background:linear-gradient(135deg,#2b1b74,#6d4dff 62%,#8e67ff);color:#fff;border:0;box-shadow:0 18px 34px rgba(74,58,190,.24);}.rp-grand-prize h3{font-size:20px;margin:8px 0 5px;}.rp-grand-prize p{color:rgba(255,255,255,.86);}.rp-grand-prize .rp-pill{background:rgba(255,216,77,.95);}.rp-grand-prize-visual{height:110px;border-radius:24px;background:radial-gradient(circle at 30% 25%,rgba(255,216,77,.95),transparent 26%),linear-gradient(160deg,#f5fbff,#dff2ff);display:grid;grid-template-columns:1fr 1fr;place-items:center;box-shadow:inset 0 0 0 6px rgba(255,255,255,.26);overflow:hidden;}.rp-grand-prize-visual span{font-size:32px;filter:drop-shadow(0 8px 10px rgba(20,30,60,.18));}.rp-grand-prize-visual span:first-child{grid-column:1/-1;font-size:42px;margin-bottom:-18px;}.rp-ticket-price-card{display:grid;gap:12px;background:linear-gradient(135deg,#fffaf0,#eef7ff);border-color:#f4dc7d;}.rp-ticket-price-card b{display:block;font-size:15px;color:var(--blue);margin-bottom:4px;}.rp-ticket-price-card span{font-size:12px;color:var(--ink-2);font-weight:800;}.rp-ticket-price-card .rp-btn{width:100%;}.rp-ticket-builder .rp-btn{width:100%;min-height:42px;margin-top:10px;}.rp-selected-numbers{min-height:42px;border-radius:16px;background:#f4f8f5;border:1px dashed #cfe0d2;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px;color:var(--ink-2);font-size:12px;font-weight:800;text-align:center;}.rp-selected-numbers i{font-style:normal;display:inline-grid;place-items:center;width:29px;height:29px;border-radius:50%;background:var(--blue);color:#fff;font-weight:900;}.rp-number-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:7px;margin-bottom:12px;}.rp-number-grid button{aspect-ratio:1;border-radius:14px;background:#fff;border:1px solid #dfe8e1;color:var(--ink);font-weight:900;box-shadow:0 4px 12px rgba(30,80,50,.05);transition:.15s;}.rp-number-grid button.is-selected{background:var(--blue);color:#fff;border-color:var(--blue);transform:translateY(-2px);box-shadow:0 8px 18px rgba(11,61,145,.22);}.rp-ticket-actions{position:sticky;bottom:0;z-index:4;display:grid;grid-template-columns:1fr;gap:8px;margin:0 -4px 12px;padding:8px 4px;background:linear-gradient(180deg,rgba(244,247,244,0),#f4f7f4 28%);}.rp-empty-ticket{background:#fff7da;border:1px solid var(--yellow);border-radius:18px;padding:14px;text-align:center;margin-bottom:12px;}.rp-empty-ticket p{font-size:13px;color:#7a5c00;margin:4px 0 10px;}.rp-my-tickets{display:grid;gap:8px;}.rp-ticket-chip{display:flex;justify-content:space-between;gap:10px;align-items:center;background:#f4f8f5;border-radius:14px;padding:10px;font-size:12px;font-weight:900;animation:rpTicketIn .35s ease;}.rp-ticket-chip span{display:flex;gap:4px;}.rp-ticket-chip i{font-style:normal;background:#fff;border:1px solid #dfe8e1;border-radius:999px;min-width:25px;text-align:center;padding:3px 5px;color:var(--blue);}@keyframes rpTicketIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:none}}
.rp-basket-balance{text-align:center;background:linear-gradient(135deg,#fff,#fff8da);border-color:#f4dc7d;}.rp-basket-balance b{display:block;font-size:28px;color:var(--blue);}.rp-basket{position:relative;height:318px;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.72),transparent 22%),radial-gradient(circle at 84% 12%,rgba(255,216,77,.72),transparent 24%),linear-gradient(180deg,#143f9d 0%,#6d4dff 43%,#ffd84d 100%);border:0;border-radius:30px;overflow:hidden;margin-bottom:12px;box-shadow:inset 0 0 0 8px rgba(255,255,255,.22),0 18px 38px rgba(34,45,150,.24);}.rp-basket::before,.rp-basket::after{content:"";position:absolute;left:0;right:0;height:70px;z-index:2;pointer-events:none;}.rp-basket::before{top:0;background:linear-gradient(#143f9d,rgba(20,63,157,0));}.rp-basket::after{bottom:0;background:linear-gradient(rgba(255,216,77,0),#ffd84d);}.rp-basket-pointer{position:absolute;left:16px;right:16px;bottom:24px;height:86px;border:3px solid #fff;border-radius:26px;z-index:3;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;background:rgba(11,61,145,.36);box-shadow:0 14px 30px rgba(11,61,145,.24),inset 0 0 0 1px rgba(255,255,255,.28);}.rp-prize-lane{position:absolute;left:18px;right:18px;top:0;display:grid;gap:10px;will-change:transform;}.rp-prize-item{height:82px;border-radius:24px;background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.76);display:flex;align-items:center;gap:13px;padding:0 14px;font-weight:900;line-height:1.12;box-shadow:0 10px 22px rgba(20,30,80,.18);}.rp-prize-item span{font-size:38px;display:grid;place-items:center;width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,#eef6ff,#fff7da);flex-shrink:0;}.rp-prize-item.is-result{border-color:var(--yellow);background:#fff7da;box-shadow:0 0 0 4px rgba(255,216,77,.35),0 16px 30px rgba(11,61,145,.2);}.rp-prize-lane.is-spinning{transition:transform 2.8s cubic-bezier(.12,.78,.12,1);}.rp-prize-cta{display:flex;justify-content:center;margin:-2px 0 12px;}.rp-prize-cta .rp-btn{min-width:min(100%,260px);min-height:52px;border-radius:18px;box-shadow:0 14px 30px rgba(11,61,145,.3);}.rp-prize-result{min-height:48px;border-radius:18px;background:#fff;padding:13px;text-align:center;font-size:13px;color:var(--ink-2);font-weight:800;margin-bottom:10px;}.rp-prize-result.is-win{color:var(--green);background:#eaf6ec;}
.rp-report-map{height:180px;border-radius:26px;background:linear-gradient(135deg,#dff0ff,#eaf6ec);position:relative;overflow:hidden;margin-bottom:12px;border:1px solid #dfe8e1;}.rp-report-map::before{content:"";position:absolute;inset:auto -20px -36px;height:110px;border-radius:50% 50% 0 0;background:#bfe0c2;}.rp-route{position:absolute;left:40px;right:48px;top:78px;border-top:4px dashed var(--blue);transform:rotate(-9deg);}.rp-report-map span{position:absolute;right:22px;top:24px;background:#fff;border-radius:999px;padding:8px 12px;font-weight:900;color:var(--blue);}.rp-report-list{background:#fff;border:1px solid #e3ebe4;border-radius:22px;overflow:hidden;margin-bottom:12px;}.rp-report-list li{display:flex;justify-content:space-between;gap:12px;padding:13px 14px;border-bottom:1px solid #eef2ef;font-size:13px;}.rp-report-list li:last-child{border-bottom:none;}.rp-report-list span{color:var(--ink-2);}.rp-report-list b{text-align:right;color:var(--ink);}.rp-stamps-row{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:12px;}.rp-stamps-row span{background:#fff;border:1px dashed #cfded2;border-radius:16px;padding:12px;font-weight:900;color:var(--blue);}.rp-report-note{font-size:13px!important;color:var(--ink-2)!important;}.rp-report-link{display:block;font-size:13px!important;color:var(--blue)!important;font-weight:900;text-decoration:underline;text-underline-offset:3px;}
.rp-bottom-nav{position:absolute;left:0;right:0;bottom:0;height:74px;background:#fff;border-top:1px solid #e3ebe4;display:grid;grid-template-columns:repeat(5,1fr);padding:7px 6px 9px;}.rp-bottom-nav button{display:grid;place-items:center;gap:2px;border-radius:15px;color:#687483;font-size:11px;font-weight:900;}.rp-bottom-nav span{font-size:19px;line-height:1;}.rp-bottom-nav button.is-active{background:#eaf6ec;color:var(--green);}.rp-app-screen .rp-bottom-nav{position:fixed;z-index:20;height:calc(74px + env(safe-area-inset-bottom));padding-bottom:calc(9px + env(safe-area-inset-bottom));box-shadow:0 -12px 30px rgba(30,80,50,.08);}.rp-app-screen .rp-bottom-nav{max-width:760px;margin-inline:auto;}.rp-toast{position:absolute;left:18px;right:18px;bottom:86px;z-index:10;background:#142033;color:#fff;border-radius:18px;padding:13px 16px;text-align:center;font-size:13px;font-weight:800;box-shadow:var(--shadow);opacity:0;transform:translateY(14px);pointer-events:none;transition:.22s;}.rp-app-screen .rp-toast{position:fixed;z-index:30;left:max(18px,calc((100vw - 760px) / 2 + 18px));right:max(18px,calc((100vw - 760px) / 2 + 18px));bottom:calc(86px + env(safe-area-inset-bottom));}.rp-toast.show{opacity:1;transform:none;}

.rp-phone-frame--preview{z-index:1;width:330px;height:680px;min-height:0;border-width:8px;border-radius:38px;box-shadow:var(--shadow-lg);transform:none;pointer-events:auto;}
.rp-phone-frame--preview .rp-statusbar{height:30px;padding-inline:18px;font-size:11px;}
.rp-phone-frame--preview .rp-app-header{height:58px;padding-inline:13px;}
.rp-phone-frame--preview .rp-app-header b{font-size:15px;}.rp-phone-frame--preview .rp-app-header span{font-size:11px;}
.rp-phone-frame--preview .rp-icon-btn{width:31px;height:31px;border-radius:11px;}
.rp-phone-frame--preview .rp-app-scroll{height:calc(100% - 162px);padding:12px 12px 18px;overflow-y:auto;}
.rp-phone-frame--preview .rp-hero-card,.rp-phone-frame--preview .rp-card{border-radius:22px;padding:13px;margin-bottom:10px;}
.rp-phone-frame--preview .rp-hero-top{margin-bottom:8px;}.rp-phone-frame--preview .rp-pill{font-size:10px;padding:5px 8px;}
.rp-phone-frame--preview .rp-forest-visual{height:158px;border-radius:20px;margin-bottom:12px;}
.rp-phone-frame--preview .rp-hero-card h2{font-size:21px;}.rp-phone-frame--preview .rp-hero-card p{font-size:12px;line-height:1.35;}
.rp-phone-frame--preview .rp-balance-row{gap:7px;margin-bottom:10px;}.rp-phone-frame--preview .rp-balance-row div{padding:10px 6px;border-radius:16px;}.rp-phone-frame--preview .rp-balance-row b{font-size:23px;}.rp-phone-frame--preview .rp-balance-row span{font-size:10px;}
.rp-phone-frame--preview .rp-card-title{font-size:11px;}.rp-phone-frame--preview .rp-card small{font-size:10px;}
.rp-phone-frame--preview .rp-btn{min-height:42px;border-radius:14px;font-size:12px;}.rp-phone-frame--preview .rp-bottom-nav{height:74px;}
.rp-phone-frame--preview .rp-ticket-topline{gap:6px;}.rp-phone-frame--preview .rp-ticket-balance{padding:9px 6px;border-radius:16px;}.rp-phone-frame--preview .rp-ticket-balance b{font-size:21px;}
.rp-phone-frame--preview .rp-number-grid{grid-template-columns:repeat(6,1fr);gap:5px;}.rp-phone-frame--preview .rp-number-grid button{min-height:30px;font-size:11px;}
.rp-phone-frame--preview .rp-basket{height:220px;border-radius:22px;}.rp-phone-frame--preview .rp-prize-item{height:62px;font-size:11px;}.rp-phone-frame--preview .rp-prize-item span{width:40px;height:40px;font-size:26px;}
.rp-phone-frame--preview .rp-toast{bottom:84px;font-size:12px;}

/* ====================================================================
   Анимация появления при скролле
   ==================================================================== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.is-visible{opacity:1;transform:none;}

/* ====================================================================
   Адаптив
   ==================================================================== */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;text-align:center;}
  .hero-copy .lead{margin-inline:auto;}
  .hero-thesis,.hero-actions{justify-content:center;}
  .hero-phone{margin-top:20px;}
  .app-demo{grid-template-columns:1fr;}
  .interface-grid{grid-template-columns:repeat(2,1fr);}
  .demo-controls{order:2;}
  .demo-phone-wrap{order:1;}
  .screen-tabs{justify-content:center;}
  .trust-grid,.donate-grid,.benefits-cols{grid-template-columns:1fr;gap:28px;}
  .prize-showcase{grid-template-columns:1fr;}
  .hybrid-grid{grid-template-columns:1fr;}
  .hybrid-plus{transform:rotate(90deg);}
  .steps{grid-template-columns:repeat(2,1fr);}
  .main-nav{display:none;}
  .prototype-brief{grid-template-columns:1fr;}
  .prototype-brief-tags{align-items:flex-start;flex-direction:row;flex-wrap:wrap;}
  .prototype-stage{grid-template-columns:1fr;}
  .prototype-controls{grid-template-columns:repeat(3,1fr);}
  .prototype-toggles{grid-template-columns:1fr 1fr;}
  .rp-prototype-shell{grid-template-columns:1fr;gap:24px;align-items:start;}
  .rp-prototype-note{max-width:720px;justify-self:center;text-align:center;}
  .rp-note-grid{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:680px){
  .section{padding:60px 0;}
  .container{padding:0 18px;}
  .cards-3,.sub-plans,.stamps-grid{grid-template-columns:1fr;}
  .ritual{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .donate-options{grid-template-columns:1fr 1fr;}
  .sub-plan--reco{transform:none;}
  .sub-plan--reco:hover{transform:translateY(-5px);}
  .header-cta{display:none;}
  .prize-main{flex-direction:column;text-align:center;}
  .prize-showcase{padding:20px;}
  .interface-grid{grid-template-columns:1fr;}
  .interface-card{text-align:left;}
  .prize-screen-mock{max-width:310px;}
  .hero-copy h1{font-size:clamp(34px,10vw,48px);}
  .prototype-shell{padding:12px;}
  .prototype-topbar{align-items:flex-start;flex-direction:column;}
  .prototype-brief{padding:16px;}
  .prototype-controls{display:flex;overflow-x:auto;padding:10px;}
  .prototype-stage .screen-tab{width:auto;flex:0 0 auto;}
  .prototype-toggles{grid-template-columns:1fr;}
  .lead{font-size:18px;}
  .legal-note{flex-direction:column;gap:10px;}
  .rp-prototype-page{background:#f4f7f4;}
  .rp-prototype-shell{display:block;padding:0;min-height:100vh;}
  .rp-prototype-note{display:none;}
  .rp-phone-frame{width:100vw;height:100dvh;min-height:100dvh;border:0;border-radius:0;box-shadow:none;}
  .rp-phone-frame .rp-app-scroll{height:calc(100dvh - 170px);padding-inline:12px;}
  .rp-forest-visual{height:178px;}
  .rp-ticket-actions{grid-template-columns:1fr;}
  .rp-number-grid{gap:6px;}
}
@media (max-width:380px){
  .phone--live{width:288px;}
}

/* Доступность: уважение к настройке reduce-motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
}
/* Видимый фокус для клавиатуры */
:focus-visible{outline:3px solid var(--yellow);outline-offset:2px;border-radius:4px;}
