/* ===== Подари вторую жизнь — design system ===== */
:root{
  --primary:#0d9488;
  --primary-600:color-mix(in srgb, var(--primary) 88%, #000);
  --primary-700:color-mix(in srgb, var(--primary) 76%, #000);
  --primary-50:color-mix(in srgb, var(--primary) 11%, #fff);
  --primary-100:color-mix(in srgb, var(--primary) 22%, #fff);
  --accent:#f5784f;
  --accent-600:color-mix(in srgb, var(--accent) 86%, #000);
  --accent-50:color-mix(in srgb, var(--accent) 13%, #fff);

  --bg:#f9f4ea;
  --bg-warm:#f1e7d6;
  --surface:#ffffff;
  --surface-2:#fcf9f3;
  --ink:#27302b;
  --ink-soft:#5f6b62;
  --ink-faint:#8d978c;
  --line:#ece3d3;
  --line-strong:#ddd0bb;

  --radius:22px;        /* tweakable */
  --radius-sm:14px;
  --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(29,43,41,.05), 0 2px 6px rgba(13,148,136,.05);
  --shadow:0 6px 22px rgba(13,148,136,.09), 0 2px 8px rgba(29,43,41,.05);
  --shadow-lg:0 18px 50px rgba(13,148,136,.16), 0 6px 18px rgba(29,43,41,.07);

  --font-display:'Nunito', system-ui, sans-serif;  /* tweakable */
  --font-body:'Manrope', system-ui, sans-serif;     /* tweakable */
  --maxw:1180px;
  --header-h:68px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
  overscroll-behavior-y:none;
}
h1,h2,h3,h4{font-family:var(--font-display);margin:0;line-height:1.12;letter-spacing:-.015em;font-weight:800}
p{margin:0}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
img{max-width:100%}
::selection{background:var(--primary-100)}

/* scrollbar */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px;border:3px solid var(--bg)}

.app{min-height:100vh;display:flex;flex-direction:column}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:clamp(52px,7vw,104px) 0}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  border:none;border-radius:var(--radius-pill);
  font-family:var(--font-display);font-weight:800;font-size:16px;
  padding:14px 22px;line-height:1;white-space:nowrap;
  transition:transform .16s ease, box-shadow .2s ease, background .2s ease, color .2s;
  -webkit-tap-highlight-color:transparent;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn svg{width:1.2em;height:1.2em;flex:none}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 8px 18px rgba(13,148,136,.28)}
.btn-primary:hover{background:var(--primary-600);box-shadow:0 10px 24px rgba(13,148,136,.34)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 8px 18px rgba(251,140,0,.28)}
.btn-accent:hover{background:var(--accent-600)}
.btn-ghost{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary-700);background:var(--primary-50)}
.btn-soft{background:var(--primary-50);color:var(--primary-700)}
.btn-soft:hover{background:var(--primary-100)}
.btn-lg{font-size:18px;padding:18px 28px}
.btn-sm{font-size:14px;padding:10px 16px}
.btn-block{width:100%}
.btn-danger{background:#fff;color:#c0392b;border:1px solid #f0cfca}
.btn-danger:hover{background:#fdecea}

.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);color:var(--ink)}
.iconbtn:hover{color:var(--primary);border-color:var(--primary-100)}
.iconbtn svg{width:20px;height:20px}

/* ===== Header ===== */
.header{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--bg) 82%, transparent);backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid var(--line)}
.header-in{height:var(--header-h);display:flex;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:900;font-size:21px;letter-spacing:-.02em;cursor:pointer}
.brand .mark{flex:none}
.brand-lock{display:flex;flex-direction:column;line-height:1.04}
.brand-name{font-family:var(--font-display);font-weight:900;font-size:18px;letter-spacing:-.025em;white-space:nowrap}
.brand-slogan{font-size:11px;font-weight:600;color:var(--ink-faint);margin-top:3px;white-space:nowrap}
.footer .brand-slogan{color:#7fa8a1}
.brand b{color:var(--primary-700)}
.nav{display:flex;align-items:center;gap:4px;margin-left:8px}
.nav a{padding:9px 15px;border-radius:var(--radius-pill);font-weight:700;font-size:15.5px;color:var(--ink-soft);transition:.16s;white-space:nowrap}
.nav a:hover{color:var(--ink);background:var(--surface)}
.nav a.active{color:var(--primary-700);background:var(--primary-50)}
.header-cta{margin-left:auto;display:flex;align-items:center;gap:10px}

/* ===== Bottom nav (mobile) ===== */
.botnav{display:none}
@media(max-width:760px){
  .botnav{
    display:grid;grid-template-columns:repeat(4,1fr);
    position:fixed;bottom:0;left:0;right:0;z-index:70;
    background:color-mix(in srgb,var(--surface) 92%, transparent);backdrop-filter:blur(16px);
    border-top:1px solid var(--line);padding:7px 6px calc(7px + env(safe-area-inset-bottom));
  }
  .botnav button{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--ink-faint);font-family:var(--font-display);font-weight:800;font-size:11px;padding:5px 0;border-radius:12px}
  .botnav button svg{width:23px;height:23px}
  .botnav button.active{color:var(--primary)}
  .app{padding-bottom:74px}
}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:clamp(28px,5vw,64px) 0 clamp(40px,5vw,72px)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--accent-50);color:var(--accent-600);font-family:var(--font-display);font-weight:800;font-size:13.5px;padding:7px 14px;border-radius:var(--radius-pill);letter-spacing:.01em}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.hero h1{font-size:clamp(38px,5.4vw,62px);font-weight:900;letter-spacing:-.03em;margin:20px 0 0}
.hero h1 .hl{color:var(--primary-700);position:relative;white-space:nowrap}
.hero h1 .hl svg{position:absolute;left:-2%;bottom:-12px;width:104%;height:16px;color:var(--accent)}
.hero .lede{font-size:clamp(17px,2vw,20px);color:var(--ink-soft);margin-top:22px;max-width:30em}
.hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-stats{display:flex;gap:26px;margin-top:34px}
.hero-stats .s b{font-family:var(--font-display);font-weight:900;font-size:26px;color:var(--ink);display:block}
.hero-stats .s span{font-size:14px;color:var(--ink-faint);font-weight:600}
.hero-stats .div{width:1px;background:var(--line-strong)}

.hero-collage{position:relative;height:clamp(360px,42vw,500px)}
.hero-collage .ph{position:absolute;border-radius:26px;overflow:hidden;box-shadow:var(--shadow-lg);border:5px solid #fff}
.hero-collage .ph img{width:100%;height:100%;object-fit:cover;display:block}
.hero-collage .p1{width:60%;height:74%;left:0;top:8%;z-index:2;rotate:-3deg}
.hero-collage .p2{width:46%;height:54%;right:0;top:0;z-index:3;rotate:4deg}
.hero-collage .p3{width:44%;height:46%;right:4%;bottom:0;z-index:3;rotate:-2deg}
.hero-blob{position:absolute;border-radius:50%;filter:blur(8px);z-index:0}
.hero-floater{position:absolute;z-index:5;background:#fff;border-radius:var(--radius-pill);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;padding:9px 15px 9px 10px;font-family:var(--font-display);font-weight:800;font-size:14px}
.hero-floater .av{width:34px;height:34px;border-radius:50%;background:var(--primary-50);display:grid;place-items:center;color:var(--primary);flex:none}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:8px;text-align:left}
  .hero-collage{height:300px;margin-top:8px;max-width:440px}
  .hero-stats{gap:18px}
}

/* ===== Pet grid + card ===== */
.pet-grid{display:grid;gap:22px;grid-template-columns:repeat(var(--cols,4),1fr)}
@media(max-width:1024px){.pet-grid{grid-template-columns:repeat(min(var(--cols,4),3),1fr)}}
@media(max-width:760px){.pet-grid{grid-template-columns:repeat(2,1fr);gap:14px}}

.pet-card{
  background:var(--surface);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);
  display:flex;flex-direction:column;cursor:pointer;
  transition:transform .2s cubic-bezier(.2,.7,.3,1), box-shadow .25s, border-color .2s;
}
.pet-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.pet-card .photo{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--bg-warm)}
.pet-card .photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.pet-card:hover .photo img{transform:scale(1.06)}
.pet-card .fav{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:color-mix(in srgb,#fff 80%,transparent);backdrop-filter:blur(6px);border:none;display:grid;place-items:center;color:var(--ink-soft);box-shadow:var(--shadow-sm)}
.pet-card .fav svg{width:19px;height:19px}
.pet-card .fav.on{color:var(--accent)}
.pet-card .fav.on svg{fill:var(--accent)}
.pet-card .match{position:absolute;left:10px;top:10px;background:var(--primary);color:#fff;font-family:var(--font-display);font-weight:900;font-size:13px;padding:6px 11px;border-radius:var(--radius-pill);box-shadow:0 4px 12px rgba(13,148,136,.4);display:flex;align-items:center;gap:5px}
.pet-card .match.hi{background:var(--accent);box-shadow:0 4px 12px rgba(251,140,0,.45)}
.pet-card .species-tag{position:absolute;left:10px;bottom:10px;background:color-mix(in srgb,#fff 86%,transparent);backdrop-filter:blur(6px);font-family:var(--font-display);font-weight:800;font-size:12px;padding:4px 10px;border-radius:var(--radius-pill);color:var(--ink);display:flex;align-items:center;gap:5px}
.pet-card .body{padding:13px 15px 15px;display:flex;flex-direction:column;gap:8px;flex:1}
.pet-card .name{font-family:var(--font-display);font-weight:900;font-size:19px;letter-spacing:-.01em;display:flex;align-items:center;gap:7px}
.pet-card .name .sx{font-size:15px}
.pet-card .meta{color:var(--ink-soft);font-size:13.5px;font-weight:600;display:flex;flex-wrap:wrap;gap:4px 9px}
.pet-card .meta .mi{display:inline-flex;align-items:center;gap:4px}
.pet-card .meta .mi svg{width:14px;height:14px;color:var(--ink-faint)}
.pet-card .loc{margin-top:auto;font-size:12.5px;color:var(--ink-faint);font-weight:600;display:flex;align-items:center;gap:5px;padding-top:4px}
.pet-card .loc svg{width:13px;height:13px;flex:none}
.sx-m{color:#2f86c9}.sx-f{color:#e25aa0}

/* ===== Section heads ===== */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(26px,3.4vw,38px);font-weight:900;letter-spacing:-.02em}
.sec-head p{color:var(--ink-soft);margin-top:7px;font-size:16px}
.sec-head .link{color:var(--primary-700);font-family:var(--font-display);font-weight:800;display:inline-flex;align-items:center;gap:6px}
.sec-head .link svg{width:17px;height:17px;transition:transform .18s}
.sec-head .link:hover svg{transform:translateX(3px)}

/* ===== Chips / segmented ===== */
.chips{display:flex;gap:9px;flex-wrap:wrap}
.chip{background:var(--surface);border:1px solid var(--line);color:var(--ink-soft);font-family:var(--font-display);font-weight:800;font-size:14px;padding:9px 15px;border-radius:var(--radius-pill);transition:.16s;display:inline-flex;align-items:center;gap:7px}
.chip:hover{border-color:var(--primary-100);color:var(--ink)}
.chip.on{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 5px 13px rgba(13,148,136,.25)}
.chip svg{width:16px;height:16px}

.seg{display:inline-flex;background:var(--bg-warm);padding:5px;border-radius:var(--radius-pill);gap:4px}
.seg button{border:none;background:none;font-family:var(--font-display);font-weight:800;font-size:15px;color:var(--ink-soft);padding:9px 20px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;gap:8px;transition:.16s}
.seg button svg{width:18px;height:18px}
.seg button.on{background:var(--surface);color:var(--primary-700);box-shadow:var(--shadow-sm)}

/* ===== Footer ===== */
.footer{margin-top:auto;background:#11302d;color:#cfe3df}
.footer .wrap{padding:54px 20px 40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.footer h4{font-family:var(--font-display);color:#fff;font-size:16px;margin-bottom:16px;font-weight:800}
.footer a,.footer p{color:#a8c8c2;font-size:14.5px;display:block;margin-bottom:10px;font-weight:500}
.footer a:hover{color:#fff}
.footer .brand{color:#fff;margin-bottom:14px}
.footer .brand b{color:#5fd6c8}
.footer .fnote{color:#7fa8a1;font-size:14px;max-width:30em;line-height:1.6}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#7fa8a1;font-size:13.5px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}.footer-grid .fcol-brand{grid-column:1/-1}}

/* ===== Skeleton ===== */
.sk{position:relative;overflow:hidden;background:var(--bg-warm);border-radius:8px}
.sk::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);transform:translateX(-100%);animation:shimmer 1.35s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.sk-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.sk-card .sk{border-radius:0}

/* ===== Empty / error ===== */
.empty{text-align:center;padding:64px 20px;max-width:440px;margin:0 auto}
.empty .ico{width:96px;height:96px;border-radius:50%;background:var(--primary-50);display:grid;place-items:center;margin:0 auto 22px;color:var(--primary)}
.empty .ico svg{width:46px;height:46px}
.empty h3{font-size:23px;font-weight:900;margin-bottom:10px}
.empty p{color:var(--ink-soft);margin-bottom:22px;font-size:15.5px}

/* ===== Pills / badges ===== */
.tag{display:inline-flex;align-items:center;gap:6px;background:var(--primary-50);color:var(--primary-700);font-family:var(--font-display);font-weight:800;font-size:13px;padding:6px 12px;border-radius:var(--radius-pill)}
.tag.gray{background:var(--bg-warm);color:var(--ink-soft)}
.tag.accent{background:var(--accent-50);color:var(--accent-600)}

/* ===== Page enter ===== */
.page{animation:fadeUp .4s cubic-bezier(.2,.7,.3,1) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.stagger>*{animation:fadeUp .5s cubic-bezier(.2,.7,.3,1) both}

/* utility */
.muted{color:var(--ink-soft)}
.center{text-align:center}
.row{display:flex;align-items:center;gap:10px}
.spread{display:flex;align-items:center;justify-content:space-between;gap:12px}
.hide-mobile{}
@media(max-width:760px){.hide-mobile{display:none !important}}
.hide-desktop{display:none !important}
@media(max-width:760px){.hide-desktop{display:initial !important}}

/* ===== Scan animation (photo search) ===== */
.scan-line{position:absolute;left:0;right:0;height:42px;background:linear-gradient(180deg,rgba(13,148,136,0),color-mix(in srgb,var(--primary) 55%,transparent) 70%,rgba(255,255,255,.9));border-bottom:2.5px solid #fff;box-shadow:0 0 22px color-mix(in srgb,var(--primary) 60%,transparent);animation:scanmove 1.7s cubic-bezier(.5,0,.5,1) infinite}
@keyframes scanmove{0%{top:-42px}100%{top:100%}}
.scan-dot{position:absolute;transform:translate(-50%,-50%);z-index:4;animation:fadeUp .4s both}
.scan-dot-core{display:block;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--primary);box-shadow:0 0 0 0 color-mix(in srgb,var(--primary) 50%,transparent);animation:dotpulse 1.4s infinite}
@keyframes dotpulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--primary) 55%,transparent)}70%{box-shadow:0 0 0 12px color-mix(in srgb,var(--primary) 0%,transparent)}100%{box-shadow:0 0 0 0 transparent}}
.scan-dot-label{position:absolute;left:22px;top:50%;transform:translateY(-50%);white-space:nowrap;background:#fff;color:var(--ink);font-family:var(--font-display);font-weight:800;font-size:12px;padding:4px 9px;border-radius:99px;box-shadow:var(--shadow);animation:fadeUp .35s both}
.scan-box{position:absolute;border:2px dashed rgba(255,255,255,.9);border-radius:12px;background:color-mix(in srgb,var(--primary) 11%,transparent);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 22%,transparent);animation:boxin .35s both;z-index:3;pointer-events:none}
@keyframes boxin{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:none}}
.scan-spin{animation:spin 1.1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== Responsive layout overrides ===== */
@media(max-width:860px){
  .cta-band{grid-template-columns:1fr !important}
  .detail-grid{grid-template-columns:1fr !important}
  .detail-grid>div:first-child{position:static !important}
  .sc-hero{grid-template-columns:1fr !important}
}
@media(max-width:760px){
  .catalog-layout{grid-template-columns:1fr !important}
  .filter-aside{display:none !important}
  .filter-toggle{display:inline-flex !important}
  .form-2col{grid-template-columns:1fr !important}
  .param-grid{grid-template-columns:1fr 1fr !important}
  .hero h1 .hl{white-space:normal}
  .about-steps{grid-template-columns:1fr !important}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .scan-line{display:none}
}

/* ===== Quiz (подбор) ===== */
.quiz-card{background:var(--surface);border:1px solid var(--line);border-radius:calc(var(--radius) + 6px);padding:clamp(22px,3.5vw,40px);box-shadow:var(--shadow)}
.quiz-progress{height:8px;background:var(--bg-warm);border-radius:99px;overflow:hidden}
.quiz-progress>div{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:99px;transition:width .45s cubic-bezier(.4,0,.2,1)}
.quiz-opts{display:grid;grid-template-columns:repeat(var(--qcols,2),1fr);gap:14px;margin-top:6px}
.quiz-opt{display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;background:var(--surface-2);border:2px solid var(--line);border-radius:var(--radius);padding:26px 16px;cursor:pointer;transition:transform .16s,border-color .16s,background .16s,box-shadow .2s;font-family:var(--font-body)}
.quiz-opt:hover{border-color:var(--primary-100);background:var(--surface);transform:translateY(-3px);box-shadow:var(--shadow)}
.quiz-opt.on{border-color:var(--primary);background:var(--primary-50);box-shadow:0 10px 24px color-mix(in srgb,var(--primary) 22%,transparent)}
.qo-ico{width:64px;height:64px;border-radius:50%;background:var(--primary-50);color:var(--primary);display:grid;place-items:center;transition:.2s}
.qo-ico svg{width:31px;height:31px}
.quiz-opt:hover .qo-ico,.quiz-opt.on .qo-ico{background:var(--primary);color:#fff}
.qo-label{font-family:var(--font-display);font-weight:800;font-size:18px}
.qo-hint{font-size:12.5px;color:var(--ink-faint);font-weight:600;line-height:1.3}
@media(max-width:560px){.quiz-opts{grid-template-columns:1fr 1fr !important}.qo-ico{width:54px;height:54px}.qo-ico svg{width:26px;height:26px}}

/* ===== Hero B (immersive) ===== */
.hl-light{color:#fff;white-space:nowrap}
.hero-b{position:relative;border-radius:calc(var(--radius) + 10px);overflow:hidden;min-height:clamp(430px,52vw,560px);display:flex;align-items:center;box-shadow:var(--shadow-lg)}
.hero-b-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-b-shade{position:absolute;inset:0;background:linear-gradient(100deg,rgba(18,38,35,.84) 0%,rgba(18,38,35,.55) 46%,rgba(18,38,35,.04) 100%)}
.hero-b-content{position:relative;z-index:2;padding:clamp(26px,5vw,64px);max-width:640px}
.hero-b-content h1{color:#fff;font-size:clamp(38px,5.6vw,66px);font-weight:900;letter-spacing:-.03em;margin:18px 0 0}
.hero-b-content .lede{margin-top:20px;max-width:27em}
.hero-b-content .hero-cta{margin-top:30px}
.hero-b-pet{position:absolute;right:clamp(16px,3vw,30px);bottom:clamp(16px,3vw,30px);z-index:3;display:flex;align-items:center;gap:12px;background:color-mix(in srgb,#fff 92%,transparent);backdrop-filter:blur(8px);border:none;border-radius:var(--radius-pill);padding:8px 16px 8px 8px;box-shadow:var(--shadow-lg);cursor:pointer;transition:transform .18s}
.hero-b-pet:hover{transform:translateY(-3px)}
.hbp-photo{width:46px;height:46px;border-radius:50%;overflow:hidden;flex:none}
.hbp-photo img{width:100%;height:100%;object-fit:cover}
.hbp-txt{display:flex;flex-direction:column;text-align:left;line-height:1.12}
.hbp-eyebrow{font-size:11px;font-weight:800;color:var(--accent-600);font-family:var(--font-display)}
.hbp-name{font-family:var(--font-display);font-weight:900;font-size:15px;display:flex;align-items:center;gap:5px}
@media(max-width:560px){.hero-b-pet{display:none}}

/* ===== Second-chance teaser (home) ===== */
.second-teaser{width:100%;display:flex;align-items:center;gap:16px;text-align:left;background:linear-gradient(100deg,var(--accent-50),var(--surface));border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;cursor:pointer;transition:transform .18s,box-shadow .2s,border-color .2s;box-shadow:var(--shadow-sm);font-family:var(--font-body)}
.second-teaser:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--accent) 30%,transparent)}
.st-ico{width:48px;height:48px;border-radius:14px;background:var(--accent);color:#fff;display:grid;place-items:center;flex:none;box-shadow:0 6px 14px color-mix(in srgb,var(--accent) 35%,transparent)}
.st-ico svg{width:24px;height:24px}
.st-txt{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.st-txt b{font-family:var(--font-display);font-weight:900;font-size:17px}
.st-txt span{color:var(--ink-soft);font-size:14px;font-weight:500}

/* ===== Second chance ===== */
.sc-hero{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 14%,var(--bg)),var(--bg));border-radius:calc(var(--radius) + 8px);padding:clamp(28px,5vw,56px);border:1px solid var(--line);position:relative;overflow:hidden}
.wait-badge{position:absolute;left:10px;top:10px;background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:800;font-size:12px;padding:6px 11px;border-radius:var(--radius-pill);box-shadow:0 4px 12px color-mix(in srgb,var(--accent) 40%,transparent);display:flex;align-items:center;gap:5px;z-index:2}
.wait-badge svg{width:13px;height:13px}

/* ===== Adoption funnel modal ===== */
.modal-overlay{position:fixed;inset:0;z-index:120;background:rgba(20,32,30,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:18px;animation:mfade .2s}
@keyframes mfade{from{opacity:0}to{opacity:1}}
.modal-card{background:var(--bg);width:100%;max-width:546px;max-height:92vh;border-radius:calc(var(--radius) + 6px);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px 12px}
.modal-body{padding:2px 22px 6px;overflow:auto;flex:1}
.modal-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 22px;border-top:1px solid var(--line);background:var(--surface-2)}
.modal-card .quiz-progress{margin:0 22px 20px !important;width:auto}

.check-row{display:flex;gap:13px;align-items:flex-start;text-align:left;width:100%;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;cursor:pointer;transition:border-color .15s,background .15s;font-family:var(--font-body)}
.check-row:hover{border-color:var(--primary-100)}
.check-row.on{border-color:var(--primary);background:var(--primary-50)}
.check-box{width:24px;height:24px;border-radius:8px;border:2px solid var(--line-strong);display:grid;place-items:center;flex:none;color:#fff;transition:.15s;margin-top:1px}
.check-row.on .check-box{background:var(--primary);border-color:var(--primary)}
.check-txt{display:flex;flex-direction:column;gap:2px}
.ct-label{font-family:var(--font-display);font-weight:800;font-size:14.5px;line-height:1.3}
.ct-sub{font-size:13px;color:var(--ink-soft);font-weight:500}

.contract-box{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;max-height:228px;overflow:auto;margin-bottom:16px}
.contract-box p{font-size:13.5px;color:var(--ink-soft);line-height:1.55;margin:0 0 10px}
.contract-box p:last-child{margin-bottom:0}
.contract-box b{color:var(--ink)}

.adopt-steps{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.adopt-steps span{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-weight:800;font-size:12px;color:var(--ink-soft);background:var(--surface-2);border:1px solid var(--line);border-radius:99px;padding:5px 11px 5px 5px}
.adopt-steps b{width:18px;height:18px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:11px;flex:none}
