:root{
  --bg:#F3F1EA; --card:#FFFFFF; --ink:#16201C; --muted:#7E867F;
  --line:#E7E3D6; --accent:#16604C; --accent-soft:#E4EFE9; --gold:#C2A24E; --gold-soft:#F3ECD8;
  --navy:#1C2B33; --shadow:0 10px 30px rgba(20,35,28,.10); --radius:20px; --danger:#B5543C;
  --serif:'Cinzel',Georgia,'Times New Roman',serif;
  --sans:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Noto Sans Georgian',sans-serif;
  /* Telegram theme overrides (если открыто в Telegram) */
  --tg-bg: var(--bg);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;font-family:var(--sans);background:var(--bg);color:var(--ink)}
#app-root{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}

.tg-header{flex:0 0 auto;height:54px;display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--bg);position:sticky;top:0;z-index:20}
.tg-header.bordered{border-bottom:1px solid var(--line)}
.tg-back{width:34px;height:34px;border-radius:50%;display:none;align-items:center;justify-content:center;cursor:pointer;color:var(--accent);font-size:22px;background:transparent;border:none}
.tg-back.show{display:flex}
.tg-title{font-size:16px;font-weight:700;flex:1;text-align:center;margin-right:34px}
.tg-title.brand{font-family:var(--serif);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:15px;color:var(--accent)}
.tg-title.left{text-align:left;margin-right:0}
.lang-pill{display:flex;align-items:center;gap:5px;background:var(--card);border:1px solid var(--gold);border-radius:20px;padding:5px 10px;font-size:12px;font-weight:600;cursor:pointer}

.screen{flex:1 1 auto;overflow-y:auto;padding:0 16px 24px}
.tabbar{flex:0 0 auto;height:64px;display:flex;background:var(--card);border-top:1px solid var(--line);position:sticky;bottom:0}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;color:var(--muted);cursor:pointer;font-weight:600}
.tab.active{color:var(--accent)}
.tab .ic{font-size:20px;line-height:1}
.mainbtn{flex:0 0 auto;padding:10px 16px 16px;background:var(--bg);position:sticky;bottom:64px}
.mainbtn.no-tabs{bottom:0}
.mainbtn button{width:100%;border:none;background:var(--accent);color:#fff;font-size:16px;font-weight:700;padding:15px;border-radius:14px;cursor:pointer;box-shadow:0 8px 20px rgba(22,96,76,.30);letter-spacing:.2px}
.mainbtn button:active{transform:translateY(1px)}
.hidden{display:none!important}

h1{font-size:25px;font-weight:800;letter-spacing:-.3px;margin:6px 0 10px}
h1.serif,h2.serif{font-family:var(--serif);font-weight:700;letter-spacing:.5px}
h2{font-size:20px;font-weight:800;margin:18px 2px 12px}
p.lead{font-size:15px;line-height:1.55;color:#46514d;margin:0 0 14px}
.muted{color:var(--muted)} .center{text-align:center}

.welcome-wrap{text-align:center;padding-top:18px}
.emblem{width:230px;height:230px;border-radius:50%;margin:0 auto;position:relative;padding:7px;
  background:linear-gradient(145deg,#E7D49B,#C2A24E 45%,#9C7E33 70%,#E7D49B);box-shadow:0 18px 44px rgba(20,35,28,.28)}
.emblem .inner{width:100%;height:100%;border-radius:50%;overflow:hidden;position:relative;
  background:radial-gradient(120% 80% at 50% 120%, rgba(12,30,22,.55), transparent 60%),
   linear-gradient(180deg,#9cc3e6 0%,#bcd3e0 34%,#7d97a0 46%,#4f6b56 60%,#2f4a37 100%);
  background-size:cover;background-position:center;display:flex;align-items:flex-start;justify-content:center}
.emblem .inner.has-photo::after{display:none}
.emblem .inner::after{content:"";position:absolute;left:8%;right:8%;bottom:6%;height:46%;
  background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(0,0,0,.12)),
   repeating-linear-gradient(90deg,rgba(255,255,255,.10) 0 10px,transparent 10px 22px);
  border-radius:8px;opacity:.5}
.emblem .ring-text{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-shadow:0 2px 10px rgba(10,20,15,.45)}
.emblem .ring-text .k{font-family:var(--serif);font-weight:700;font-size:30px;letter-spacing:1px;line-height:1}
.emblem .ring-text .c{font-family:var(--serif);font-weight:600;font-size:13px;letter-spacing:5px;margin-top:6px;display:flex;align-items:center;gap:8px}
.emblem .ring-text .c::before,.emblem .ring-text .c::after{content:"";width:18px;height:1px;background:rgba(255,255,255,.8)}

.value-row{display:flex;gap:10px;margin:6px 0 4px}
.value{flex:1;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:12px;text-align:center}
.value .e{font-size:22px}.value .t{font-size:11px;font-weight:600;margin-top:4px;line-height:1.3}

.lang-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.lang-card{background:var(--card);border:2px solid var(--line);border-radius:18px;padding:18px 14px;text-align:center;cursor:pointer;transition:.15s}
.lang-card .fl{font-size:30px}.lang-card .nm{font-weight:700;margin-top:8px;font-size:15px}
.lang-card.sel{border-color:var(--accent);background:var(--accent-soft)}

.goal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.goal{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:16px 14px;cursor:pointer;box-shadow:var(--shadow);min-height:104px;display:flex;flex-direction:column;justify-content:space-between;transition:.15s}
.goal:active{transform:scale(.98)}
.goal .e{font-size:26px}.goal .t{font-weight:700;font-size:14px;line-height:1.25;margin-top:10px}
.goal .s{font-size:11px;color:var(--muted);margin-top:2px}

.toolbar{display:flex;gap:8px;align-items:center;margin:6px 0 12px;position:sticky;top:54px;background:var(--bg);padding:8px 0;z-index:5}
.chips-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}
.chip{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:8px 12px;font-size:12px;font-weight:600;white-space:nowrap;cursor:pointer}
.chip.act{background:var(--accent);color:#fff;border-color:var(--accent)}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:14px;cursor:pointer}
.card .ph{height:190px;position:relative;background-size:cover;background-position:center}
.card .vbadge{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);color:var(--accent);font-size:11px;font-weight:800;padding:5px 10px;border-radius:20px;display:flex;align-items:center;gap:4px}
.card .gbadge{background:var(--gold);color:#3a2c06}
.card .fav{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;font-size:17px;border:none;cursor:pointer}
.card .fav.on{color:var(--danger)}
.card .body{padding:13px 14px}
.card .price{font-size:19px;font-weight:800}
.card .params{display:flex;gap:14px;color:#46514d;font-size:13px;margin-top:7px;flex-wrap:wrap}
.card .params span{display:flex;align-items:center;gap:4px}
.card .desc{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.gallery{height:260px;border-radius:20px;background-size:cover;background-position:center;margin-top:8px;position:relative}
.gallery-carousel{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;margin-top:8px;-webkit-overflow-scrolling:touch}
.gallery-carousel::-webkit-scrollbar{height:0}
.cslide{min-width:100%;height:270px;border-radius:22px;background-size:cover;background-position:center;scroll-snap-align:center;flex:0 0 auto;box-shadow:0 8px 24px rgba(24,38,31,.12)}
.cslide.cvid{background:#000;display:flex;align-items:center;justify-content:center}
.cslide.cvid video{width:100%;height:100%;object-fit:cover;border-radius:22px}
.detail-price{font-size:26px;font-weight:800;margin-top:14px}
.spec{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.spec .it{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:11px 13px}
.spec .it .l{font-size:11px;color:var(--muted)}.spec .it .v{font-size:14px;font-weight:700;margin-top:2px}
.btn-row{display:flex;gap:10px;margin-top:16px}
.btn{flex:1;border:none;border-radius:13px;padding:13px;font-size:14px;font-weight:700;cursor:pointer}
.btn.pri{background:var(--accent);color:#fff}.btn.sec{background:var(--card);color:var(--ink);border:1px solid var(--line)}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.linkbtn{background:none;border:none;color:var(--danger);font-size:13px;font-weight:600;cursor:pointer;display:block;margin:14px auto 0}

.cat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:6px}
.cat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 6px;text-align:center;cursor:pointer}
.cat .e{font-size:22px}.cat .t{font-size:10.5px;font-weight:600;margin-top:6px;line-height:1.2}
.cat{position:relative}
.cat.dim{opacity:.42;cursor:default}
.cat .cnt{position:absolute;top:6px;right:6px;background:var(--accent);color:#fff;font-size:9px;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.cat.dim .cnt{display:none}
.stars{display:flex;gap:4px;font-size:26px;cursor:pointer;justify-content:center;margin:6px 0 12px}
.stars span{color:var(--line)}
.stars span.on{color:var(--gold)}
.review{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:10px}
.review .top{display:flex;justify-content:space-between;font-size:13px}
.review .au{font-weight:700}
.review .rt{color:var(--gold);font-weight:700}
.review .tx{font-size:13px;color:#46514d;margin-top:6px;line-height:1.4}
.gallery-strip{display:flex;gap:8px;overflow-x:auto;margin-top:10px}
.gallery-strip img{height:120px;border-radius:12px;flex:0 0 auto;cursor:zoom-in}
.cslide[data-zoom]{cursor:zoom-in}
.lightbox{position:fixed;inset:0;background:rgba(8,12,10,.95);z-index:100;opacity:0;pointer-events:none;transition:.2s;backdrop-filter:blur(4px)}
.lightbox.show{opacity:1;pointer-events:auto}
.lb-track{position:absolute;inset:0;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.lb-track::-webkit-scrollbar{height:0}
.lb-slide{min-width:100%;height:100%;scroll-snap-align:center;display:flex;align-items:center;justify-content:center;padding:16px}
.lb-slide img{max-width:100%;max-height:100%;border-radius:14px;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.lightbox .lb-close{position:absolute;top:16px;right:22px;color:#fff;font-size:26px;opacity:.9;font-weight:300;z-index:2;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);border-radius:50%}
.lightbox .lb-count{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:#fff;font-size:14px;font-weight:600;opacity:.9}
.srv{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:14px;margin-bottom:12px;box-shadow:var(--shadow);display:flex;gap:12px}
.srv .av{width:54px;height:54px;border-radius:14px;flex:0 0 auto;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;font-size:24px}
.srv .nm{font-weight:700;font-size:14px}.srv .meta{font-size:12px;color:var(--muted);margin-top:3px}.srv .rate{font-size:12px;color:var(--gold);font-weight:700;margin-top:5px}
.verif{display:inline-block;font-size:10px;font-weight:800;padding:3px 8px;border-radius:12px;background:var(--accent-soft);color:var(--accent);margin-top:6px}

.steps{display:flex;gap:6px;margin:8px 0 16px}
.steps i{flex:1;height:5px;border-radius:4px;background:var(--line)}.steps i.on{background:var(--accent)}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px}
.field .req{color:var(--danger)}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:12px;font-size:14px;font-family:inherit;background:var(--card);color:var(--ink)}
.field textarea{min-height:90px;resize:vertical}
.field .err{color:var(--danger);font-size:12px;margin-top:5px;display:none}
.field.invalid input,.field.invalid select{border-color:var(--danger)}
.field.invalid .err{display:block}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{border:1.5px solid var(--line);border-radius:20px;padding:9px 13px;font-size:13px;font-weight:600;cursor:pointer;background:var(--card)}
.opt.sel{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.uploader{border:2px dashed var(--line);border-radius:16px;padding:22px;text-align:center;color:var(--muted);font-size:13px;cursor:pointer}
.uploader.has{border-style:solid;border-color:var(--accent);color:var(--accent)}

.statusrow{display:flex;align-items:center;justify-content:space-between;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:10px}
.tag{font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px}
.tag.mod{background:#FFF3D6;color:#9a6b00}.tag.pub{background:var(--accent-soft);color:var(--accent)}
.tag.edit{background:#FCE5DF;color:var(--danger)}.tag.sold{background:#ECEFEE;color:var(--muted)}

.success{text-align:center;padding-top:40px}
.success .circle{width:84px;height:84px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:42px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}

.about-list{margin:4px 0}
.about-list .li{display:flex;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:10px}
.about-list .li .e{font-size:22px}.about-list .li .t{font-size:13.5px;line-height:1.4}

.empty{text-align:center;padding:50px 20px;color:var(--muted)}
.empty .e{font-size:46px}.empty .t{font-size:14px;margin-top:12px;line-height:1.5}

.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:#16201C;color:#fff;padding:11px 18px;border-radius:24px;font-size:13px;font-weight:600;opacity:0;transition:.25s;pointer-events:none;z-index:60;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.demo-banner{background:var(--gold-soft);color:#7a5f15;border:1px solid var(--gold);border-radius:12px;padding:8px 12px;font-size:12px;font-weight:600;margin:8px 0;text-align:center}

.sheet-bg{position:fixed;inset:0;background:rgba(10,20,16,.4);opacity:0;pointer-events:none;transition:.2s;z-index:40}
.sheet-bg.show{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:50%;transform:translateX(-50%) translateY(100%);bottom:0;width:100%;max-width:480px;background:var(--card);border-radius:24px 24px 0 0;padding:18px 16px 24px;transition:.25s;z-index:41}
.sheet.show{transform:translateX(-50%) translateY(0)}
.sheet h3{margin:4px 0 14px;font-size:16px;text-align:center}

/* =================================================================
   Modern "zephyr" polish — мягкие поверхности, анимации, живые кнопки
   ================================================================= */
:root{
  --bg:#F4F3EE; --card:#FFFFFF; --line:#ECE8DC;
  --shadow:0 12px 34px rgba(24,38,31,.10);
  --ease:cubic-bezier(.22,.61,.36,1);
}
html,body,#app-root{background:linear-gradient(180deg,#F6F5F0 0%,#EFEDE4 100%)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes pop{0%{opacity:0;transform:scale(.9)}100%{opacity:1;transform:scale(1)}}
@keyframes shimmer{100%{background-position:200% 0}}

/* плавная подача экрана */
.screen>*{animation:fadeUp .38s var(--ease) both}

/* единые мягкие переходы и нажатия */
button,.goal,.cat,.card,.opt,.chip,.lang-card,.value,.statusrow,.srv,.tab,.review,.about-list .li{
  transition:transform .18s var(--ease), box-shadow .28s ease, background .22s ease, border-color .22s ease, opacity .22s ease}
button:active,.goal:active,.card:active,.opt:active,.chip:active,.lang-card:active,.statusrow:active,.srv:active,.cat:not(.dim):active{transform:scale(.97)}

/* кнопки */
.mainbtn button,.btn.pri{background:linear-gradient(135deg,#1E8467 0%,#11543F 100%);
  box-shadow:0 12px 26px rgba(22,96,76,.32), inset 0 1px 0 rgba(255,255,255,.22)}
.mainbtn button{border-radius:16px;font-size:16px;padding:16px}
.mainbtn button:active,.btn.pri:active{transform:translateY(1px) scale(.99)}
.btn{border-radius:15px;transition:transform .16s var(--ease), box-shadow .25s ease}
.btn.sec{box-shadow:0 4px 14px rgba(24,38,31,.06)}
.btn.sec:active{transform:scale(.98)}

/* карточки — мягкие тени, скругления */
.card{border-radius:24px;box-shadow:0 8px 26px rgba(24,38,31,.08);border-color:rgba(236,232,220,.9)}
.card .ph{height:200px}
.card .ph.fit{height:300px}
.goal,.srv,.value,.about-list .li,.statusrow,.review{border-radius:20px}
.goal{box-shadow:0 8px 24px rgba(24,38,31,.07)}

/* поля ввода — фокус-кольцо */
.field input,.field select,.field textarea{border-radius:14px;transition:border-color .2s ease, box-shadow .2s ease}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(22,96,76,.12)}

/* чипсы/опции */
.opt,.chip{border-radius:22px}
.opt.sel{box-shadow:0 4px 12px rgba(22,96,76,.14)}

/* таб-бар */
.tabbar{box-shadow:0 -6px 24px rgba(24,38,31,.06);border-top-color:transparent}
.tab .ic{transition:transform .22s var(--ease)}
.tab.active .ic{transform:translateY(-2px) scale(1.12)}

/* эмблема и заголовки */
.emblem{animation:pop .55s var(--ease) both}
.emblem{box-shadow:0 22px 50px rgba(20,35,28,.30)}
h1.serif{letter-spacing:.3px}

/* верхняя панель/пилюля языка */
.tg-header{backdrop-filter:saturate(1.05)}
.lang-pill{box-shadow:0 4px 12px rgba(24,38,31,.08)}
.lang-pill:active{transform:scale(.96)}

/* плавный скелетон-загрузки */
.empty .t{opacity:.9}

/* всплывашка */
.toast{box-shadow:0 16px 36px rgba(0,0,0,.30);backdrop-filter:blur(10px);background:rgba(20,28,24,.94)}

/* первый экран — премиальный вид */
.welcome-wrap{text-align:center;padding-top:18px}
.emblem{box-shadow:0 22px 50px rgba(20,35,28,.30), 0 0 56px rgba(194,162,78,.28)}
.welcome-title{margin-top:24px;font-size:26px;line-height:1.1}
.gold-div{width:58px;height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:13px auto}
.welcome-sub{font-size:15px;line-height:1.55;color:#46514d;max-width:330px;margin:0 auto 8px}
.value .vic{width:48px;height:48px;border-radius:15px;margin:0 auto;background:linear-gradient(140deg,var(--accent-soft),#ffffff);display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 5px 14px rgba(22,96,76,.14)}
.value{padding:15px 8px;border-radius:18px}
.value .t{margin-top:8px}

/* информационные карточки (О клубе) — не кликабельны на вид */
.about-list.info .li{background:rgba(255,255,255,.5);box-shadow:none;border-color:var(--line);cursor:default;transform:none!important;align-items:center}
.about-list.info .li:active{transform:none!important}

/* уважение к «уменьшить движение» */
@media (prefers-reduced-motion: reduce){
  .screen>*,.emblem{animation:none}
  *{transition:none!important}
}

.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.42);color:#fff;font-size:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;user-select:none}
.lb-prev{left:14px}.lb-next{right:14px}
.lb-slide video{max-width:100%;max-height:100%;border-radius:14px}
.cslide.cvid{position:relative}
.cslide.cvid video{width:100%;height:100%;object-fit:cover;border-radius:22px}
.play-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:42px;color:#fff;background:rgba(0,0,0,.25);border-radius:22px;pointer-events:none;text-shadow:0 2px 10px rgba(0,0,0,.6)}

.gal-wrap{position:relative}
.gal-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.4);color:#fff;font-size:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:4;user-select:none}
.gal-prev{left:10px}.gal-next{right:10px}
