/* =========================================================
   ПАРИС — PREMIUM STYLE 2026 (production)
   Palette: Deep Ocean Navy + Champagne Gold + Pearl Sand
   Typography: Playfair Display (display) + Inter (UI)
   ========================================================= */
:root{
  --ocean-deep:#0B1A3A; --ocean:#1A2D5C; --ocean-mid:#2D4A7A; --ocean-light:#5B7BA8;
  --gold:#D4A55A; --gold-bright:#E8B86E; --gold-dark:#A8823F;
  --pearl:#F8F4ED; --sand:#F2EBDD; --sand-warm:#EAE0CB;
  --bg:#FBF9F4; --white:#FFFFFF;
  --ink:#0B1A3A; --text:#1F2937; --text-light:#4B5563; --text-muted:#9CA3AF;
  --line:#E5E1D6;
  --free:#10B981; --busy:#EF4444; --danger:#EF4444; --success:#10B981;
  /* legacy aliases for existing markup */
  --primary:var(--ocean-deep); --primary-light:var(--ocean-mid);
  --accent:var(--gold); --accent-dark:var(--gold-dark);
  --border:var(--line);
  /* sizing */
  --font-display:'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-ui:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-family:var(--font-ui);
  --space-1:8px; --space-2:16px; --space-3:24px; --space-4:32px; --space-5:48px;
  --radius-sm:8px; --radius-md:14px; --radius-lg:24px; --radius-xl:32px; --radius-full:9999px;
  --shadow-sm:0 1px 2px rgba(11,26,58,0.04), 0 1px 3px rgba(11,26,58,0.06);
  --shadow-md:0 4px 12px rgba(11,26,58,0.06), 0 2px 4px rgba(11,26,58,0.04);
  --shadow-lg:0 18px 40px rgba(11,26,58,0.10), 0 6px 12px rgba(11,26,58,0.06);
  --shadow-xl:0 32px 64px rgba(11,26,58,0.16);
  --shadow-gold:0 14px 32px rgba(212,165,90,0.30);
  --ease:cubic-bezier(0.22, 1, 0.36, 1);
  --transition:0.3s ease;
}

/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:80px}
body{font-family:var(--font-ui);font-size:1rem;font-weight:400;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-width:320px;overflow-x:hidden}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
ul,ol{list-style:none}
button,input,select,textarea{font-family:inherit;font-size:inherit}
button{cursor:pointer;border:none;background:none;color:inherit}
iframe{border:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ===== Type ===== */
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);font-weight:500;line-height:1.15;letter-spacing:-0.01em}
h1{font-size:clamp(2.2rem, 5.5vw, 4.5rem);font-weight:400}
h2{font-size:clamp(1.8rem, 3.5vw, 2.8rem);font-weight:500}
h3{font-size:clamp(1.15rem, 2vw, 1.4rem);font-weight:600;font-family:var(--font-ui)}
h4{font-size:1rem;font-weight:600;font-family:var(--font-ui)}
p{color:var(--text-light);line-height:1.7}
.label,.label-text,.eyebrow{display:inline-block;font-family:var(--font-ui);font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.24em;color:var(--gold-dark);margin-bottom:12px}
.eyebrow--white{color:var(--gold-bright)}

/* ===== Layout ===== */
.container{max-width:1280px;margin-inline:auto;padding-inline:24px}
.text-center{text-align:center} .text-left{text-align:left} .text-right{text-align:right}
.text-accent{color:var(--gold-dark)} .text-muted{color:var(--text-muted)}
.text-primary{color:var(--ink)} .text-white{color:var(--white)}
.mb-1{margin-bottom:var(--space-1)} .mb-2{margin-bottom:var(--space-2)}
.mb-3{margin-bottom:var(--space-3)} .mb-4{margin-bottom:var(--space-4)}
.mt-1{margin-top:var(--space-1)} .mt-2{margin-top:var(--space-2)}
.mt-3{margin-top:var(--space-3)} .mt-4{margin-top:var(--space-4)}
.flex{display:flex} .flex-col{flex-direction:column}
.items-center{align-items:center} .justify-between{justify-content:space-between}
.gap-1{gap:var(--space-1)} .gap-2{gap:var(--space-2)} .gap-3{gap:var(--space-3)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 26px;font-family:var(--font-ui);font-weight:600;font-size:0.95rem;border-radius:var(--radius-full);border:1.5px solid transparent;line-height:1;letter-spacing:0.02em;white-space:nowrap;cursor:pointer;text-decoration:none;transition:all 0.38s var(--ease);position:relative;overflow:hidden;min-height:44px}
.btn:active{transform:translateY(1px)}
.btn-cta,.btn-primary{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.btn-cta:hover,.btn-cta:focus-visible,.btn-primary:hover,.btn-primary:focus-visible{background:var(--gold-bright);border-color:var(--gold-bright);box-shadow:var(--shadow-gold);transform:translateY(-2px);color:var(--ink)}
.btn-outline{background:transparent;color:var(--ink);border-color:rgba(11,26,58,0.2)}
.btn-outline:hover,.btn-outline:focus-visible{border-color:var(--ink);background:var(--ink);color:var(--white)}
.btn-ghost-light{background:rgba(255,255,255,0.08);color:var(--white);border-color:rgba(255,255,255,0.25);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.btn-ghost-light:hover,.btn-ghost-light:focus-visible{background:rgba(255,255,255,0.16);border-color:rgba(255,255,255,0.5);color:var(--white)}
.btn-success{background:var(--success);color:var(--white);border-color:var(--success)}
.btn-success:hover{background:#0EA371;border-color:#0EA371;box-shadow:0 4px 16px rgba(16,185,129,0.3)}
.btn-sm{padding:10px 18px;font-size:0.85rem;min-height:36px}
.btn-lg{padding:18px 34px;font-size:1rem;min-height:52px}
.btn-block{width:100%}
.btn:disabled,.btn[disabled]{opacity:0.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn:disabled:hover,.btn[disabled]:hover{transform:none;box-shadow:none}
.btn-icon{width:18px;height:18px;flex-shrink:0;transition:transform 0.38s var(--ease)}
.btn:hover .btn-icon{transform:translateX(4px)}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:all 0.38s var(--ease);background:transparent}
.site-header.scrolled,.site-header.solid{background:rgba(251,249,244,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-sm);padding:12px 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:inline-flex;align-items:center;gap:10px;flex-shrink:0;font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--white);letter-spacing:0.04em;text-decoration:none;transition:color 0.3s var(--ease)}
.site-header.scrolled .logo,.site-header.solid .logo{color:var(--ink)}
.logo-mark{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:0.7rem;font-weight:700;color:var(--white);letter-spacing:0;flex-shrink:0}
.site-nav{display:flex;align-items:center;flex:1;justify-content:center}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{font-size:0.92rem;font-weight:500;color:rgba(255,255,255,0.92);text-decoration:none;letter-spacing:0.01em;position:relative;padding:6px 0;transition:color 0.3s var(--ease)}
.nav-links a::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform 0.38s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.site-header.scrolled .nav-links a,.site-header.solid .nav-links a{color:var(--text)}
.site-header.scrolled .nav-links a:hover,.site-header.solid .nav-links a:hover{color:var(--ink)}
.header-cta{flex-shrink:0;display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;width:40px;height:40px;gap:5px;border-radius:var(--radius-sm);background:none;border:none;cursor:pointer;padding:6px;transition:background-color 0.3s var(--ease)}
.nav-toggle span{display:block;width:22px;height:2px;background:currentColor;color:var(--white);border-radius:2px;transition:all 0.38s var(--ease)}
.site-header.scrolled .nav-toggle span,.site-header.solid .nav-toggle span{color:var(--ink)}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--white);overflow:hidden;background-color:#0B1A3A}
.hero-bg{position:absolute;inset:0;z-index:0;background:#0B1A3A center 40% / cover no-repeat}
.hero::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg, rgba(11,26,58,0.55) 0%, rgba(11,26,58,0.20) 30%, rgba(11,26,58,0.20) 60%, rgba(11,26,58,0.75) 100%)}
.hero::after{content:'';position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 70% 20%, rgba(212,165,90,0.20) 0%, rgba(212,165,90,0) 55%), radial-gradient(ellipse at 20% 80%, rgba(11,26,58,0.55) 0%, rgba(11,26,58,0) 60%);mix-blend-mode:soft-light}
.hero-content{position:relative;z-index:2;max-width:880px;padding:120px 24px 96px;animation:fadeUp 1s var(--ease) both}
.hero-label{display:inline-block;font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.28em;color:var(--gold-bright);margin-bottom:20px;font-family:var(--font-ui)}
.hero h1,.hero-title{font-family:var(--font-display);font-size:clamp(2.5rem, 6vw, 5rem);font-weight:400;color:var(--white);line-height:1.1;letter-spacing:-0.02em;margin-bottom:20px;text-wrap:balance}
.hero h1 em,.hero-title em{font-style:italic;color:var(--gold-bright);font-weight:400}
.hero p,.hero-subtitle,.hero .subtitle{font-size:1.12rem;color:rgba(255,255,255,0.78);max-width:560px;margin:0 auto 36px;line-height:1.7;text-wrap:pretty}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;justify-content:center;gap:48px;margin-top:48px;padding-top:32px;border-top:1px solid rgba(255,255,255,0.12);flex-wrap:wrap}
.hero-meta-item{text-align:center}
.hero-meta-num{font-family:var(--font-display);font-size:1.9rem;color:var(--gold-bright);line-height:1;margin-bottom:6px;font-weight:500}
.hero-meta-lbl{font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.55)}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,0.6);font-size:0.7rem;letter-spacing:0.24em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;animation:bounce 2.4s ease-in-out infinite}
.hero-scroll-line,.hero-scroll__line{width:1px;height:32px;background:rgba(255,255,255,0.4)}

/* ===== Section base ===== */
.section{padding:96px 0;position:relative}
.section--sand{background:var(--pearl)}
.section--white{background:var(--white)}
.section--primary,.section--ink{background:var(--ink);color:var(--white)}
.section-header,.section-head{text-align:center;max-width:680px;margin-inline:auto;margin-bottom:56px}
.section-head p,.section-header .subtitle{margin-top:16px;font-size:1.05rem}
.section-label,.section-header .label{color:var(--gold-dark)}
.section--ink .section-head .eyebrow,.section--ink .label{color:var(--gold-bright)}
.section--ink h2{color:var(--white)}
.section--ink p{color:rgba(255,255,255,0.72)}

/* ===== Trust strip ===== */
.trust-strip{padding:48px 0;background:var(--pearl);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:32px;align-items:center;text-align:center}
.trust-item{display:flex;flex-direction:column;align-items:center;gap:6px}
.trust-num{font-family:var(--font-display);font-size:2.2rem;color:var(--ink);font-weight:500;line-height:1}
.trust-num em{font-style:normal;color:var(--gold-dark)}
.trust-lbl{font-size:0.78rem;color:var(--text-light);letter-spacing:0.04em}

/* ===== Object cards ===== */
.objects-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:32px}
.object-card,.obj-card{position:relative;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;transition:all 0.38s var(--ease);display:flex;flex-direction:column;text-decoration:none;color:inherit}
.object-card:hover,.obj-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl)}
.card-photo,.obj-photo{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg, var(--ocean) 0%, var(--ocean-mid) 100%);background-size:cover;background-position:center 60%;background-repeat:no-repeat}
.card-photo::after,.obj-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg, transparent 50%, rgba(11,26,58,0.5) 100%);opacity:0;transition:opacity 0.38s var(--ease)}
.object-card:hover .card-photo::after,.obj-card:hover .obj-photo::after{opacity:1}
.card-photo img,.obj-photo img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease)}
.object-card:hover .card-photo img,.obj-card:hover .obj-photo img{transform:scale(1.06)}
.card-photo-placeholder,.obj-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.20);font-family:var(--font-display);font-size:5rem;background:linear-gradient(135deg, var(--ocean) 0%, var(--ocean-mid) 100%)}
.card-badge,.obj-badge{position:absolute;top:14px;left:14px;z-index:2;padding:6px 14px;border-radius:var(--radius-full);background:rgba(255,255,255,0.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);font-size:0.7rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);box-shadow:var(--shadow-sm)}
.card-badge--accent{background:var(--gold);color:var(--ink)}
.card-badge--free{background:var(--success);color:var(--white)}
.card-badge--busy{background:var(--danger);color:var(--white)}
.obj-fav{position:absolute;top:14px;right:14px;z-index:2;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all 0.3s var(--ease);border:none;cursor:pointer}
.obj-fav:hover{background:var(--gold);color:var(--white);transform:scale(1.1)}
.card-body,.obj-body{padding:24px;flex:1;display:flex;flex-direction:column}
.obj-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:0.78rem;color:var(--text-muted);letter-spacing:0.04em}
.obj-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--text-muted)}
.card-title,.obj-title{font-family:var(--font-display);font-size:1.5rem;font-weight:500;color:var(--ink);margin-bottom:8px;line-height:1.25;letter-spacing:-0.01em}
.card-description,.obj-desc{font-size:0.92rem;color:var(--text-light);margin-bottom:14px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-features,.obj-features{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.card-feature,.obj-feature,.feature-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-full);background:var(--pearl);font-size:0.78rem;font-weight:500;color:var(--text);border:none}
.card-feature .feature-icon,.obj-feature .feature-icon,.feature-chip .feature-icon{margin:0;font-size:inherit;color:var(--gold-dark)}
.card-feature .feature-icon svg,.obj-feature .feature-icon svg,.feature-chip .feature-icon svg{width:14px;height:14px}
.feature-label{white-space:nowrap}
.card-footer,.obj-foot{display:flex;align-items:flex-end;justify-content:space-between;padding:16px 24px 20px;border-top:1px solid var(--line);margin-top:auto}
.obj-foot{padding:16px 0 0}
.card-price,.obj-price-block{display:flex;flex-direction:column}
.obj-price-from{font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px;display:block}
/* JS-rendered card uses single span "от 1 000 ₽" — readable, slightly muted, big */
.price-from{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);font-weight:500;letter-spacing:-0.005em;text-transform:none;line-height:1;display:inline-block}
.card-capacity{display:flex;align-items:center;gap:6px;font-size:0.85rem;color:var(--text-light);margin:0 0 14px}
.card-capacity .capacity-icon{font-size:0.95rem}
.no-features,.photo-placeholder-text,.gallery-placeholder-text{color:var(--text-muted);font-size:0.85rem}
.price-value,.obj-price{font-family:var(--font-display);font-size:1.5rem;color:var(--ink);font-weight:500;line-height:1}
.price-unit,.obj-price-unit{font-family:var(--font-ui);font-size:0.85rem;color:var(--text-light);font-weight:400;margin-left:2px}
.obj-rating{display:flex;align-items:center;gap:6px;font-size:0.85rem;font-weight:600;color:var(--ink)}
.obj-rating::before{content:'★';color:var(--gold-dark)}
.btn-select{padding:8px 16px;background:var(--ink);color:var(--white);border-radius:var(--radius-full);font-size:0.78rem;font-weight:600;letter-spacing:0.04em}
.no-tariffs,.empty-message,.error-message{text-align:center;color:var(--text-muted);padding:32px 16px;font-size:0.95rem;grid-column:1 / -1}

/* ===== Features section ===== */
.features-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:32px}
.feature-item{text-align:center;padding:36px 24px;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all 0.38s var(--ease);border:1px solid transparent}
.feature-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--gold)}
.feature-item .feature-icon{width:64px;height:64px;border-radius:50%;margin:0 auto 16px;background:linear-gradient(135deg, var(--sand) 0%, var(--sand-warm) 100%);display:inline-flex;align-items:center;justify-content:center;color:var(--gold-dark);font-size:1.6rem}
.feature-item .feature-icon svg{width:28px;height:28px}
/* Card chips — small inline icons, not the big circle */
.feature-chip .feature-icon,.obj-feature .feature-icon,.card-feature .feature-icon{width:auto;height:auto;border-radius:0;background:none;margin:0;padding:0;font-size:inherit;color:var(--gold-dark);display:inline-flex;align-items:center}
.feature-chip .feature-icon img{width:14px;height:14px;object-fit:contain;display:block}
.feature-chip .feature-icon:empty{display:none}
.feature-item h3{font-family:var(--font-display);font-size:1.25rem;font-weight:500;color:var(--ink);margin-bottom:8px;letter-spacing:0}
.feature-item p{font-size:0.92rem;color:var(--text-light);line-height:1.6}

/* ===== Story split ===== */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-text h2{margin-bottom:24px}
.story-text p{margin-bottom:18px;font-size:1.02rem}
.story-quote{border-left:3px solid var(--gold);padding:18px 26px;font-family:var(--font-display);font-size:1.18rem;font-style:italic;color:var(--ink);background:var(--pearl);border-radius:0 var(--radius-md) var(--radius-md) 0;margin:24px 0;line-height:1.5}
.story-visual{position:relative;aspect-ratio:4/5;border-radius:var(--radius-xl);overflow:hidden;background:#0B1A3A center / cover no-repeat;box-shadow:var(--shadow-lg)}
.story-visual::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg, rgba(11,26,58,0) 50%, rgba(11,26,58,0.45) 100%)}
.story-floating{position:absolute;bottom:32px;left:32px;right:32px;background:rgba(255,255,255,0.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-md);padding:20px 24px;box-shadow:var(--shadow-md)}
.story-floating-row{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.story-floating-row:last-child{margin-bottom:0}
.story-floating-row strong{font-family:var(--font-display);font-size:1.15rem;color:var(--ink);font-weight:500}
.story-floating-row em{font-style:normal;font-size:0.82rem;color:var(--text-light);display:block}
.story-floating-icon{width:40px;height:40px;border-radius:10px;background:var(--gold);display:flex;align-items:center;justify-content:center;color:var(--white);flex-shrink:0}

/* ===== Gallery ===== */
.gallery-strip{padding:96px 0;background:var(--bg)}
.gallery-grid-pano{display:grid;grid-template-columns:repeat(6, 1fr);grid-auto-rows:140px;gap:8px;border-radius:var(--radius-lg);overflow:hidden}
.gallery-grid-pano .gi{position:relative;overflow:hidden;border-radius:var(--radius-md);background:var(--ocean);cursor:pointer;text-decoration:none}
.gallery-grid-pano .gi img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease)}
.gallery-grid-pano .gi:hover img{transform:scale(1.06)}
.gallery-grid-pano .gi-1{grid-column:span 2;grid-row:span 2}
.gallery-grid-pano .gi-2,.gallery-grid-pano .gi-3,.gallery-grid-pano .gi-4,.gallery-grid-pano .gi-5{grid-column:span 2}

/* ===== Reviews ===== */
.reviews-section{background:var(--ink);color:var(--white);padding:96px 0}
.reviews-section h2{color:var(--white)}
.reviews-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px}
.review-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-lg);padding:32px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all 0.38s var(--ease)}
.review-card:hover{background:rgba(255,255,255,0.07);border-color:var(--gold);transform:translateY(-4px)}
.review-stars{color:var(--gold-bright);font-size:1.05rem;margin-bottom:14px;letter-spacing:2px}
.review-text{color:rgba(255,255,255,0.88);font-size:1rem;line-height:1.65;margin-bottom:24px;font-family:var(--font-display);font-style:italic;font-weight:400}
.review-author{display:flex;align-items:center;gap:14px}
.review-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.1rem;color:var(--white);font-weight:500}
.review-name,.reviewer-name{font-weight:600;font-size:0.95rem;color:var(--white)}
.review-meta,.review-date{font-size:0.78rem;color:rgba(255,255,255,0.5);margin-top:2px}

/* ===== CTA banner ===== */
.cta-banner{position:relative;padding:96px 0;background:linear-gradient(135deg, var(--ocean-deep) 0%, var(--ocean) 100%);color:var(--white);overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 30%, rgba(212,165,90,0.18) 0%, transparent 40%), radial-gradient(circle at 20% 80%, rgba(91,123,168,0.2) 0%, transparent 40%)}
.cta-content{position:relative;z-index:1;max-width:760px;margin:0 auto;text-align:center}
.cta-content h2{color:var(--white);margin-bottom:20px}
.cta-content p{color:rgba(255,255,255,0.78);font-size:1.08rem;margin-bottom:32px}

/* ===== Quick search ===== */
.qs-bar{position:relative;z-index:3;margin:-56px auto 0;max-width:1080px;padding:0 24px}
.qs-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:24px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:8px;align-items:center}
.qs-field{display:flex;flex-direction:column;padding:8px 16px;border-right:1px solid var(--line)}
.qs-field:last-of-type{border-right:none}
.qs-field label{font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}
.qs-field select,.qs-field input{border:none;background:none;font-family:var(--font-ui);font-size:0.95rem;font-weight:500;color:var(--ink);padding:0;outline:none;width:100%}
.qs-field input::placeholder{color:var(--text-muted);font-weight:400}

/* ===== Contacts (legacy support) ===== */
.contacts-grid,.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:24px}
.contact-item{display:flex;flex-direction:column;gap:4px}
.contact-item strong{font-family:var(--font-display);font-size:1.1rem;color:var(--ink);font-weight:500}
.contact-item p{font-size:0.95rem;color:var(--text-light)}
.contact-item a{color:var(--ink);transition:color 0.3s var(--ease)}
.contact-item a:hover{color:var(--gold-dark)}
.contact-map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);background:var(--sand)}
.contact-map iframe{display:block;width:100%;height:380px;border:none}

/* ===== Footer ===== */
.site-footer{background:var(--ink);color:rgba(255,255,255,0.7);padding:96px 0 24px;border-top:1px solid rgba(255,255,255,0.06)}
.footer-grid,.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:64px;padding-bottom:48px}
.footer-col{}
.footer-logo,.footer-brand{font-family:var(--font-display);font-size:1.5rem;color:var(--white);font-weight:500;margin-bottom:14px;letter-spacing:0.04em}
.footer-brand-tag,.footer-col p{font-size:0.92rem;line-height:1.6;color:rgba(255,255,255,0.55)}
.footer-col h4{font-family:var(--font-ui);font-size:0.78rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:18px}
.footer-col ul,.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-col a,.footer-links a{font-size:0.92rem;color:rgba(255,255,255,0.7);transition:color 0.3s var(--ease)}
.footer-col a:hover,.footer-links a:hover{color:var(--gold-bright)}
.footer-socials{display:flex;gap:10px;margin-top:20px}
.footer-social{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.05);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.6);transition:all 0.3s var(--ease)}
.footer-social:hover{background:var(--gold);color:var(--ink);transform:translateY(-2px)}
.footer-bottom{padding-top:24px;border-top:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:0.82rem;color:rgba(255,255,255,0.4)}

/* ============================================================
   BOOKING WIZARD (existing flow — restyled)
   ============================================================ */
.booking-hero{padding:48px 0 16px}
.booking-hero h1{font-family:var(--font-display);font-size:clamp(2rem, 4vw, 3rem);font-weight:400;margin:0 0 16px;color:var(--ink)}
.object-summary{display:flex;gap:18px;align-items:center;color:var(--text-light);font-size:0.95rem}
.object-summary img{width:120px;height:80px;object-fit:cover;border-radius:var(--radius-md)}
.booking-wizard{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;padding:24px 0 80px;align-items:start}

/* Stepper */
.bk-stepper{display:flex;align-items:center;justify-content:center;gap:10px;margin:0 0 32px;flex-wrap:wrap}
.bk-step{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:var(--radius-full);background:var(--white);box-shadow:var(--shadow-sm);font-size:0.85rem;font-weight:500;color:var(--text-light)}
.bk-step.active{background:var(--ink);color:var(--white)}
.bk-step.done{color:var(--ink)}
.bk-step-num{width:24px;height:24px;border-radius:50%;background:var(--pearl);color:var(--text);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:0.78rem;flex-shrink:0}
.bk-step.active .bk-step-num{background:var(--gold);color:var(--ink)}
.bk-step.done .bk-step-num{background:var(--success);color:var(--white)}
.bk-step-arr{width:14px;height:14px;color:var(--line);flex-shrink:0}

/* Calendar */
.calendar-block{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-md)}
.cal-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.cal-nav button{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--white);cursor:pointer;font-size:1.1rem;color:var(--ink);transition:all 0.2s var(--ease)}
.cal-nav button:hover:not(:disabled){background:var(--ink);color:var(--white);border-color:var(--ink)}
.cal-nav button:disabled{opacity:0.3;cursor:not-allowed}
.cal-nav .cal-title{font-family:var(--font-display);font-weight:500;font-size:1.15rem;text-transform:capitalize;color:var(--ink)}
.cal-weekdays,.cal-grid{display:grid;grid-template-columns:repeat(7, 1fr);gap:6px}
.cal-weekdays{margin-bottom:8px;font-size:0.7rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:0.14em;text-align:center}
.cal-day{aspect-ratio:1/1;min-height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:0.95rem;font-weight:500;color:var(--text);background:var(--pearl);transition:all 0.2s var(--ease);cursor:pointer;border:2px solid transparent;position:relative;user-select:none}
.cal-day.empty{background:transparent;cursor:default}
.cal-day.past,.cal-day.beyond_horizon{background:transparent;color:var(--text-muted);cursor:not-allowed;opacity:0.5}
.cal-day.busy{background:rgba(239,68,68,0.10);color:var(--danger);cursor:not-allowed;opacity:0.85}
.cal-day.busy::after{content:'';position:absolute;bottom:6px;width:5px;height:5px;border-radius:50%;background:var(--danger)}
.cal-day.blocked{background:#9CA3AF;color:#fff;cursor:not-allowed}
.cal-day.free{background:var(--white);color:var(--ink);box-shadow:0 0 0 1px var(--line) inset;cursor:pointer}
.cal-day.free:hover{background:var(--gold);color:var(--ink);transform:scale(1.06);box-shadow:0 6px 14px rgba(212,165,90,0.30)}
.cal-day.free::after{content:'';position:absolute;bottom:6px;width:5px;height:5px;border-radius:50%;background:var(--success)}
.cal-day.selected{background:var(--ink);color:var(--white);box-shadow:0 0 0 3px var(--gold);border-color:transparent}
.cal-legend{display:flex;gap:18px;flex-wrap:wrap;font-size:0.82rem;color:var(--text-light);margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.cal-legend span{display:inline-flex;align-items:center;gap:8px}
.cal-legend i{width:12px;height:12px;border-radius:3px;display:inline-block}
.cal-legend .i-free{background:var(--success)}
.cal-legend .i-busy{background:var(--danger)}
.cal-legend .i-blocked{background:#9CA3AF}

/* Booking form */
.booking-form{background:var(--white);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-md);position:sticky;top:90px}
.booking-form[hidden]{display:none}
.booking-form h2{font-family:var(--font-display);font-size:1.4rem;font-weight:500;color:var(--ink);margin:0 0 6px}
.booking-form .selected-day{background:linear-gradient(135deg, var(--pearl) 0%, var(--sand) 100%);border-radius:var(--radius-md);padding:16px 20px;margin:14px 0 18px;font-size:0.95rem;color:var(--ink);line-height:1.4;border:1px solid var(--line)}
.booking-form .selected-day strong{display:block;font-family:var(--font-display);font-size:1.3rem;font-weight:500;margin-bottom:2px}
.booking-form label{display:block;font-size:0.7rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted);margin:14px 0 6px}
/* .field — канонический контрол-инпут (full-width). Эталон для всех форм. */
.field,
.booking-form input,.booking-form textarea,.booking-form select{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--radius-md);font:inherit;color:var(--ink);background:var(--white);box-sizing:border-box;transition:all 0.2s var(--ease);font-size:16px}
.field:focus,
.booking-form input:focus,.booking-form textarea:focus,.booking-form select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(212,165,90,0.15)}
.booking-form textarea{min-height:80px;resize:vertical}
/* .btn-submit — тонкий layout-хелпер: вид кнопки берётся из системы .btn .btn-primary .btn-lg .btn-block */
.btn-submit{margin-top:20px}
.booking-form .form-error{color:var(--danger);font-size:0.82rem;margin-top:6px;min-height:1.1em;line-height:1.35}

.booking-placeholder{background:var(--white);border:1.5px dashed var(--line);border-radius:var(--radius-lg);padding:48px 32px;text-align:center;color:var(--text-muted)}
.booking-placeholder h1{font-family:var(--font-display)}

.booking-success{background:var(--white);border-radius:var(--radius-lg);padding:48px;text-align:center;box-shadow:var(--shadow-lg);max-width:600px;margin:64px auto}
.booking-success h1{font-family:var(--font-display);font-size:2rem;font-weight:500;margin:0 0 16px;color:var(--success)}
.booking-success .summary{background:var(--pearl);border-radius:var(--radius-md);padding:18px;margin:24px 0;font-size:1rem;color:var(--ink);line-height:1.7}
.booking-success p{color:var(--text-light);line-height:1.6}

/* Cleaner picker for /booking without object */
.booking-picker{margin:32px auto;max-width:1200px}
.booking-picker h1{font-family:var(--font-display);font-weight:400;font-size:clamp(2rem, 4vw, 2.8rem);margin:0 0 12px;color:var(--ink)}
.booking-picker .lead{color:var(--text-light);margin:0 0 32px;font-size:1.05rem}
.picker-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:24px}
.picker-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);text-decoration:none;color:inherit;transition:all 0.38s var(--ease);display:flex;flex-direction:column}
.picker-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.picker-photo{aspect-ratio:4/3;background:linear-gradient(135deg, var(--ocean) 0%, var(--ocean-mid) 100%);overflow:hidden}
.picker-photo img{width:100%;height:100%;object-fit:cover}
.picker-body{padding:18px}
.picker-type{font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:6px}
.picker-name{font-family:var(--font-display);font-size:1.3rem;font-weight:500;color:var(--ink);margin-bottom:4px}
.picker-cap{color:var(--text-light);font-size:0.85rem}

/* ===== Skeleton ===== */
@keyframes skeleton-shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg, var(--line) 25%, #EDE8DF 50%, var(--line) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.4s ease infinite;border-radius:var(--radius-sm)}

/* ===== Animations ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.animate-fade-in-up{animation:fadeUp 0.6s ease both}
.animate-fade-in{animation:fadeIn 0.5s ease both}
.reveal{opacity:0;transform:translateY(30px);transition:all 0.8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.animate-delay-1{animation-delay:0.1s}.animate-delay-2{animation-delay:0.2s}
.animate-delay-3{animation-delay:0.3s}.animate-delay-4{animation-delay:0.4s}

/* ===== Page padding for sticky header ===== */
section[id]{scroll-margin-top:80px}
button,.btn-cta,.btn-submit,a.btn-cta{touch-action:manipulation}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .features-grid{grid-template-columns:repeat(2, 1fr)}
  .footer-grid,.footer-inner{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:900px){
  .nav-toggle{display:flex}
  .site-nav{position:fixed !important;top:0 !important;right:0 !important;bottom:0 !important;left:auto !important;width:min(320px, 80vw) !important;background:var(--white) !important;box-shadow:-8px 0 32px rgba(11,26,58,0.15) !important;transform:translateX(110%) !important;transition:transform 0.4s var(--ease) !important;z-index:1100 !important;flex-direction:column !important;padding:80px 0 24px !important;overflow-y:auto !important;justify-content:flex-start !important}
  .site-nav.open{transform:translateX(0) !important}
  .nav-links{flex-direction:column;align-items:stretch;width:100%;padding:0;gap:0}
  .nav-links li{width:100%;list-style:none}
  .nav-links a{display:block;padding:16px 24px;font-size:1rem;color:var(--ink) !important;border-bottom:1px solid var(--pearl);border-left:3px solid transparent}
  .nav-links a::after{display:none}
  .nav-links a:hover{background:var(--pearl);border-left-color:var(--gold)}
  body.nav-open{overflow:hidden}
  body.nav-open::before{content:'';position:fixed;inset:0;background:rgba(11,26,58,0.45);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:1050}
  .header-cta .btn{display:none}
  .qs-card{grid-template-columns:1fr 1fr;gap:0;padding:16px}
  .qs-field{border-right:none;border-bottom:1px solid var(--line);padding:12px 0}
  .qs-field.qs-submit{grid-column:span 2;padding-top:12px;border-bottom:none}
  .qs-field.qs-submit .btn{width:100%}
  .qs-bar{margin-top:-32px}
  .story-grid{grid-template-columns:1fr;gap:48px}
  .reviews-grid{grid-template-columns:1fr}
  .gallery-grid-pano{grid-template-columns:repeat(2, 1fr);grid-auto-rows:160px}
  .gallery-grid-pano .gi-1{grid-column:span 2;grid-row:span 1}
  .gallery-grid-pano .gi{grid-column:span 1 !important}
  .booking-wizard{grid-template-columns:1fr}
  .booking-form{position:static}
  .contact-grid,.contacts-grid{grid-template-columns:1fr;gap:32px}
}
@media(max-width:768px){
  .section{padding:64px 0}
  .gallery-strip,.reviews-section,.cta-banner{padding:64px 0}
  .section-header,.section-head{margin-bottom:40px}
  .features-grid{grid-template-columns:repeat(2, 1fr);gap:16px}
  .objects-grid{grid-template-columns:1fr;gap:20px}
  .hero-meta{gap:24px;margin-top:32px}
  .hero-meta-num{font-size:1.4rem}
}

/* =========================================================
   PUBLIC ACCOUNT (ЛК) — append to /assets/css/style.css
   ========================================================= */

/* ============ AUTH (login.php) ============ */
.auth-page{min-height:100vh;background:
  radial-gradient(ellipse at 20% 20%, rgba(212,165,90,0.20) 0%, transparent 50%),
  radial-gradient(ellipse at 80% 90%, rgba(45,74,122,0.40) 0%, transparent 55%),
  linear-gradient(135deg, var(--ocean-deep) 0%, #061026 100%);
  display:flex;align-items:center;justify-content:center;padding:80px 20px 40px;color:#fff;position:relative}
.auth-page::before{content:'';position:absolute;inset:0;background-image:
  radial-gradient(circle at 30% 40%, rgba(255,255,255,0.04) 0%, transparent 6%),
  radial-gradient(circle at 70% 60%, rgba(255,255,255,0.04) 0%, transparent 6%);
  pointer-events:none}
.auth-back{position:absolute;top:24px;left:24px;color:rgba(255,255,255,0.7);text-decoration:none;font-size:0.88rem;display:inline-flex;align-items:center;gap:6px;transition:color .2s}
.auth-back:hover{color:#fff}
.auth-shell{position:relative;width:100%;max-width:460px}
.auth-eyebrow{display:block;font-size:0.7rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:14px;text-align:center}
.auth-hello{font-family:var(--font-display);font-size:clamp(2rem, 5vw, 2.6rem);color:#fff;text-align:center;margin-bottom:8px;font-weight:400;line-height:1.1;letter-spacing:-0.01em}
.auth-hello em{font-style:italic;color:var(--gold-bright);font-weight:400}
.auth-sub{text-align:center;color:rgba(255,255,255,0.65);font-size:0.95rem;margin-bottom:32px;line-height:1.5}
.auth-card{background:rgba(255,255,255,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;padding:36px 32px;box-shadow:0 32px 64px rgba(0,0,0,0.35), 0 0 0 1px rgba(255,255,255,0.05);color:var(--text)}
.auth-tabs{display:flex;background:var(--pearl);padding:4px;border-radius:99px;margin-bottom:24px;gap:0}
.auth-tab{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:99px;font-family:var(--font-ui);font-weight:500;font-size:0.88rem;color:var(--text-light);cursor:pointer;transition:all .25s var(--ease);display:inline-flex;align-items:center;justify-content:center;gap:6px}
.auth-tab.active{background:var(--ink);color:#fff;box-shadow:0 4px 12px rgba(11,26,58,0.20)}
.auth-tab svg{width:14px;height:14px}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:0.7rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.auth-field input{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--radius-md);font-family:inherit;color:var(--ink);background:#fff;transition:all .2s var(--ease);font-size:16px}
.auth-field input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(212,165,90,0.15)}
.auth-otp-input{font-family:ui-monospace,monospace;font-size:1.6rem !important;letter-spacing:0.5em;text-align:center;font-weight:600;padding:16px !important}
.auth-action{width:100%;padding:14px;background:var(--gold);color:var(--ink);border:none;border-radius:99px;font-weight:600;font-size:0.95rem;letter-spacing:0.02em;cursor:pointer;transition:all .3s var(--ease);min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.auth-action:hover:not(:disabled){background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 14px 32px rgba(212,165,90,0.30)}
.auth-action:disabled{opacity:0.5;cursor:not-allowed;transform:none;box-shadow:none}
.auth-resend{display:block;text-align:center;margin-top:14px;color:var(--text-muted);font-size:0.85rem}
.auth-resend a{color:var(--gold-dark);text-decoration:underline;cursor:pointer}
.auth-error{background:rgba(239,68,68,0.08);color:var(--danger);border:1px solid rgba(239,68,68,0.25);border-radius:10px;padding:10px 12px;margin-top:12px;font-size:0.85rem;min-height:0;display:none}
.auth-error.show{display:block}
.auth-tg-cta{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;background:#0088CC;color:#fff;border-radius:99px;text-decoration:none;font-weight:600;font-size:0.95rem;transition:all .25s}
.auth-tg-cta:hover{background:#0077B5;transform:translateY(-1px);box-shadow:0 8px 20px rgba(0,136,204,0.40)}
.auth-tg-status{margin-top:14px;text-align:center;color:var(--text-muted);font-size:0.85rem;display:flex;align-items:center;justify-content:center;gap:8px}
.auth-tg-status .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gold);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(1.3)}}

/* ============ ACCOUNT HERO ============ */
.account-hero{padding:96px 0 32px;background:linear-gradient(180deg, var(--pearl) 0%, var(--bg) 100%)}
.acc-greeting{display:flex;align-items:center;gap:18px;margin-bottom:32px}
.acc-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.9rem;color:#fff;font-weight:500;flex-shrink:0;box-shadow:0 12px 24px rgba(212,165,90,0.35)}
.acc-hello{font-family:var(--font-display);font-size:clamp(1.8rem, 4vw, 2.6rem);font-weight:400;color:var(--ink);line-height:1.1;letter-spacing:-0.01em}
.acc-hello em{font-style:italic;color:var(--gold-dark)}
.acc-sub{font-size:0.95rem;color:var(--text-light);margin-top:6px}

.acc-tiles{display:grid;grid-template-columns:repeat(4, 1fr);gap:16px;margin-bottom:24px}
.acc-tile{background:var(--white);border-radius:18px;padding:20px;border:1px solid var(--line);position:relative;overflow:hidden;transition:all .3s var(--ease)}
.acc-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.acc-tile-label{font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);font-weight:600;margin-bottom:8px}
.acc-tile-value{font-family:var(--font-display);font-size:2rem;color:var(--ink);font-weight:500;line-height:1}
.acc-tile-value .unit{font-family:var(--font-ui);font-size:0.85rem;color:var(--text-light);font-weight:400;margin-left:3px}
.acc-tile-meta{font-size:0.78rem;color:var(--text-muted);margin-top:8px}
@media(max-width:900px){.acc-tiles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.acc-tiles{grid-template-columns:1fr;gap:12px}}

/* Loyalty meter inline in hero */
.acc-loyalty{background:linear-gradient(135deg, var(--ocean-deep) 0%, var(--ocean) 100%);border-radius:18px;padding:24px 26px;color:#fff;position:relative;overflow:hidden;box-shadow:0 18px 40px rgba(11,26,58,0.20)}
.acc-loyalty::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 90% 10%, rgba(212,165,90,0.25) 0%, transparent 40%)}
.acc-loyalty-inner{position:relative}
.acc-loyalty-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.acc-loyalty-tier{display:inline-flex;align-items:center;gap:10px}
.acc-loyalty-tier-icon{width:42px;height:42px;border-radius:50%;background:rgba(212,165,90,0.20);border:1.5px solid var(--gold-bright);display:flex;align-items:center;justify-content:center;color:var(--gold-bright);font-family:var(--font-display);font-size:1rem;font-weight:600}
.acc-loyalty-tier-name{font-family:var(--font-display);font-size:1.3rem;font-weight:500;line-height:1.1}
.acc-loyalty-tier-sub{font-size:0.78rem;color:rgba(255,255,255,0.65);margin-top:2px}
.acc-loyalty-discount{font-family:var(--font-display);font-size:1.6rem;color:var(--gold-bright);font-weight:500}
.acc-loyalty-bar{height:6px;background:rgba(255,255,255,0.10);border-radius:99px;overflow:hidden;margin-bottom:10px}
.acc-loyalty-bar-fill{height:100%;background:linear-gradient(90deg, var(--gold-bright) 0%, var(--gold) 100%);border-radius:99px;transition:width 1s var(--ease)}
.acc-loyalty-progress{display:flex;justify-content:space-between;font-size:0.78rem;color:rgba(255,255,255,0.65)}
.acc-loyalty-progress strong{color:#fff;font-weight:600}

/* ============ TABS ============ */
.acc-tabs{display:flex;gap:6px;background:var(--pearl);padding:4px;border-radius:99px;margin-bottom:24px;align-self:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch}
.acc-tab{padding:10px 18px;border:none;background:transparent;border-radius:99px;font-family:var(--font-ui);font-weight:500;font-size:0.88rem;color:var(--text-light);cursor:pointer;transition:all .25s var(--ease);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.acc-tab.active{background:var(--ink);color:#fff;box-shadow:0 4px 12px rgba(11,26,58,0.15)}
.acc-tab .acc-tab-count{background:rgba(0,0,0,0.10);color:inherit;font-size:0.7rem;padding:1px 7px;border-radius:99px;min-width:18px;text-align:center}
.acc-tab.active .acc-tab-count{background:rgba(255,255,255,0.20);color:#fff}

/* ============ BOOKING CARDS ============ */
.acc-bookings{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.bk-card{
  display:grid;grid-template-columns:96px 1fr auto;gap:18px;align-items:center;
  background:var(--white);border:1px solid var(--line);border-radius:18px;padding:18px 22px;
  transition:all .25s var(--ease);position:relative;overflow:hidden;
}
.bk-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:transparent}
.bk-card[data-status="cancelled"],
.bk-card[data-status="refunded"]{opacity:0.65}
.bk-card[data-status="pending"]{border-color:rgba(245,158,11,0.45)}
.bk-card[data-status="pending"]::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg, transparent, var(--gold), transparent);animation:shimmer 2s ease-in-out infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

.bk-date{
  text-align:center;background:var(--pearl);border-radius:14px;padding:14px 8px;
  border:1px solid var(--line-soft, var(--line));
}
.bk-date-day{font-family:var(--font-display);font-size:2rem;color:var(--ink);font-weight:500;line-height:1}
.bk-date-month{font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-dark);margin-top:4px;font-weight:600}
.bk-date-year{font-size:0.7rem;color:var(--text-muted);margin-top:2px}
.bk-card[data-soon="true"] .bk-date{background:linear-gradient(135deg, #FEF3C7 0%, #FDE68A 100%);border-color:var(--gold)}
.bk-card[data-soon="true"] .bk-date-day{color:var(--gold-dark)}

.bk-info-title{font-family:var(--font-display);font-size:1.3rem;font-weight:500;color:var(--ink);margin-bottom:6px}
.bk-info-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:0.85rem;color:var(--text-light);margin-bottom:8px}
.bk-info-meta span{display:inline-flex;align-items:center;gap:4px}
.bk-info-meta span svg{width:13px;height:13px;color:var(--text-muted)}
.bk-info-bottom{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.bk-info-price{font-family:var(--font-display);font-size:1.1rem;color:var(--gold-dark);font-weight:500}
.bk-countdown{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:var(--pearl);border-radius:99px;font-size:0.75rem;color:var(--gold-dark);font-weight:600}
.bk-countdown::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gold)}

.bk-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.bk-act{
  display:inline-flex;align-items:center;gap:6px;padding:8px 14px;
  border-radius:99px;border:1.5px solid var(--line);background:#fff;color:var(--text);
  font-family:inherit;font-size:0.82rem;font-weight:500;cursor:pointer;text-decoration:none;
  transition:all .2s var(--ease);white-space:nowrap;
}
.bk-act:hover{border-color:var(--ink);color:var(--ink)}
.bk-act svg{width:13px;height:13px}
.bk-act-pay{background:var(--gold);color:var(--ink);border-color:var(--gold);font-weight:600}
.bk-act-pay:hover{background:var(--gold-bright);border-color:var(--gold-bright);box-shadow:0 6px 16px rgba(212,165,90,0.30)}
.bk-act-danger{color:var(--danger);border-color:rgba(239,68,68,0.30);background:rgba(239,68,68,0.04)}
.bk-act-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}

.bk-locked{font-size:0.72rem;color:var(--text-muted);margin-top:6px;font-style:italic;text-align:right;max-width:160px;line-height:1.4}

/* Empty state */
.acc-empty{
  background:var(--white);border:1.5px dashed var(--line);border-radius:18px;
  padding:48px 24px;text-align:center;color:var(--text-muted);
}
.acc-empty-icon{width:64px;height:64px;border-radius:50%;background:var(--pearl);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--gold-dark)}
.acc-empty-icon svg{width:28px;height:28px}
.acc-empty h3{font-family:var(--font-display);font-size:1.4rem;font-weight:500;color:var(--ink);margin-bottom:6px}
.acc-empty p{font-size:0.95rem;color:var(--text-light);margin-bottom:18px;max-width:440px;margin-left:auto;margin-right:auto}

/* Skeleton */
.bk-skel{display:grid;grid-template-columns:96px 1fr auto;gap:18px;align-items:center;background:var(--white);border-radius:18px;padding:18px 22px}
.bk-skel-box{background:linear-gradient(90deg,var(--line) 25%,#EDE8DF 50%,var(--line) 75%);background-size:800px 100%;animation:skeleton-shimmer 1.4s ease infinite;border-radius:8px}

/* ============ MESSENGER LIST ============ */
.acc-section{margin-bottom:48px}
.acc-section h2{font-family:var(--font-display);font-size:1.6rem;font-weight:500;color:var(--ink);margin-bottom:20px;letter-spacing:-0.01em}
.acc-section .acc-section-sub{font-size:0.92rem;color:var(--text-light);margin-top:-12px;margin-bottom:18px}

.msgr-list{display:flex;flex-direction:column;gap:10px}
.msgr-row{
  display:flex;align-items:center;gap:14px;padding:18px 22px;
  background:var(--white);border:1px solid var(--line);border-radius:14px;
  transition:all .25s var(--ease);
}
.msgr-row:hover{border-color:var(--gold);background:var(--pearl)}
.msgr-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-weight:700}
.msgr-icon[data-channel="email"]{background:linear-gradient(135deg,#3B82F6,#1D4ED8)}
.msgr-icon[data-channel="telegram"]{background:linear-gradient(135deg,#0088CC,#005A8E)}
.msgr-icon[data-channel="max"]{background:linear-gradient(135deg,#FF6B6B,#E54B4B)}
.msgr-info{flex:1;min-width:0}
.msgr-name{font-weight:600;color:var(--ink);font-size:0.95rem}
.msgr-detail{font-size:0.82rem;color:var(--text-muted);margin-top:2px;font-family:ui-monospace,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msgr-status{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:99px;font-size:0.75rem;font-weight:600}
.msgr-status[data-active="1"]{background:rgba(16,185,129,0.12);color:#047857}
.msgr-status[data-active="1"]::before{content:'';width:6px;height:6px;border-radius:50%;background:#10B981}
.msgr-status[data-active="0"]{background:var(--pearl);color:var(--text-muted)}
.msgr-action{padding:8px 14px;border-radius:99px;border:1.5px solid var(--line);background:#fff;color:var(--text);font-family:inherit;font-size:0.82rem;font-weight:500;cursor:pointer;text-decoration:none}
.msgr-action:hover{border-color:var(--ink);color:var(--ink)}
.msgr-pref-row{padding:14px 22px;background:var(--pearl);border-radius:14px;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:10px;flex-wrap:wrap}
.msgr-pref-row label{font-size:0.85rem;color:var(--text-light)}
.msgr-pref-row select{padding:8px 12px;border:1.5px solid var(--line);border-radius:var(--radius-md);background:#fff;font-family:inherit;color:var(--ink);font-size:16px}

/* ============ PROFILE ============ */
.acc-profile{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:32px}
@media(max-width:768px){.acc-profile{grid-template-columns:1fr}}
.acc-profile-row{padding:14px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:14px}
.acc-profile-row:last-child{border-bottom:none}
.acc-profile-k{font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);font-weight:600}
.acc-profile-v{color:var(--text);font-weight:500}
.acc-profile-edit{font-size:0.82rem;color:var(--gold-dark);text-decoration:underline;cursor:pointer}

/* ============ MODAL ============ */
/* .modal-bg/.modal/.modal-actions — канонический модал; .acc-modal* — легаси-алиас (account.js) */
.modal-bg,
.acc-modal-bg{position:fixed;inset:0;background:rgba(11,26,58,0.45);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:2000;display:none;align-items:center;justify-content:center;padding:20px}
.modal-bg.show,.acc-modal-bg.show{display:flex;animation:fadeIn .3s ease}
.modal,
.acc-modal{background:var(--white);border-radius:var(--radius-lg);padding:36px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 32px 64px rgba(0,0,0,0.30);animation:slideUp .35s var(--ease)}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal h3,.acc-modal h3{font-family:var(--font-display);font-size:1.4rem;font-weight:500;color:var(--ink);margin-bottom:8px}
.modal p,.acc-modal p{color:var(--text-light);font-size:0.92rem;margin-bottom:18px}
.modal-actions,
.acc-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;flex-wrap:wrap}
.acc-modal input[type=date]{width:100%;padding:14px;border:1.5px solid var(--line);border-radius:var(--radius-md);font-family:inherit;font-size:16px}

/* ============ TOAST (плавающее уведомление) ============ */
/* .toast — канонический класс; .acc-toast — легаси-алиас (account.js) */
.toast,
.acc-toast{
  position:fixed;top:20px;right:20px;background:var(--ink);color:#fff;
  padding:14px 20px;border-radius:var(--radius-md);font-size:0.9rem;font-weight:500;
  box-shadow:0 18px 40px rgba(0,0,0,0.30);z-index:3000;
  display:none;align-items:center;gap:10px;
  animation:toastIn .3s var(--ease);max-width:calc(100vw - 40px);
}
.toast.show,.acc-toast.show{display:inline-flex}
.toast.success,.acc-toast.success{background:#047857}
.toast.error,.acc-toast.error{background:var(--danger)}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ============ ALERT (инлайн-сообщение/баннер) ============ */
.alert{padding:14px 18px;border-radius:var(--radius-md);border:1px solid transparent;font-size:0.92rem;line-height:1.45;margin-bottom:16px}
.alert-error{background:#FEF2F2;border-color:#FCA5A5;color:#991B1B}
.alert-success{background:#ECFDF5;border-color:#6EE7B7;color:#065F46}
.alert-warning{background:#FEF7E5;border-color:#E8D9B0;color:#A8823F}
.alert-info{background:#EFF6FF;border-color:#BFDBFE;color:#1E40AF}

/* ============ FIELD-ERROR (ошибка поля) ============ */
.field-error,.sup-error,.err-msg{color:var(--danger);font-size:0.82rem;margin-top:6px;min-height:1.1em;line-height:1.35}

/* ============ MOBILE ============ */
@media(max-width:768px){
  .account-hero{padding:80px 0 24px}
  .acc-greeting{margin-bottom:24px}
  .acc-avatar{width:60px;height:60px;font-size:1.5rem}
  .bk-card{grid-template-columns:80px 1fr;gap:14px;padding:14px 16px}
  .bk-actions{grid-column:1 / -1;flex-direction:row;align-items:stretch;gap:8px;margin-top:8px;padding-top:14px;border-top:1px solid var(--line);justify-content:flex-start;flex-wrap:wrap}
  .bk-actions .bk-act{flex:1;min-width:0;justify-content:center;font-size:0.78rem}
  .bk-locked{display:none}
  .acc-section h2{font-size:1.3rem}
  .msgr-row{padding:14px;flex-wrap:wrap}
  .msgr-info{flex:1 1 calc(100% - 60px)}
  .msgr-status, .msgr-action{order:3}
}
@media(max-width:480px){
  .bk-date{padding:10px 6px}
  .bk-date-day{font-size:1.6rem}
  .acc-tile-value{font-size:1.6rem}
}

/* =========================================================
   BROADCAST + WEATHER — append to /assets/css/style.css
   ========================================================= */

/* ============ Broadcast hero ============ */
.bc-hero{padding:120px 0 32px;background:linear-gradient(180deg, var(--ocean-deep) 0%, var(--ocean) 60%, var(--bg) 100%);color:#fff;position:relative;overflow:hidden}
.bc-hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(circle at 80% 20%, rgba(212,165,90,0.15) 0%, transparent 40%),
  radial-gradient(circle at 20% 80%, rgba(91,123,168,0.18) 0%, transparent 40%);pointer-events:none}
.bc-hero-inner{position:relative;z-index:1;text-align:center;max-width:760px;margin:0 auto}
.bc-hero .eyebrow{color:var(--gold-bright)}
.bc-hero h1{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.6rem);font-weight:400;color:#fff;line-height:1.1;letter-spacing:-0.01em;margin-bottom:14px}
.bc-hero h1 em{font-style:italic;color:var(--gold-bright);font-weight:400}
.bc-hero p{color:rgba(255,255,255,0.72);font-size:1rem;max-width:560px;margin:0 auto}

/* Live indicator */
.live-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;background:rgba(239,68,68,0.18);
  border:1px solid rgba(239,68,68,0.45);border-radius:99px;
  font-size:0.75rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;
  color:#FCA5A5;margin-bottom:18px;
}
.live-pill::before{content:'';width:7px;height:7px;border-radius:50%;background:#EF4444;animation:livePulse 1.4s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(1.4)}}

/* ============ Camera frame ============ */
.bc-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:24px;margin-top:-32px;position:relative;z-index:2;padding-bottom:48px}
@media(max-width:980px){.bc-grid{grid-template-columns:1fr}}

.cam-card{
  position:relative;background:#0B1A3A;border-radius:24px;overflow:hidden;
  box-shadow:0 32px 64px rgba(11,26,58,0.30);
  aspect-ratio:16/10;
}
.cam-card iframe{width:100%;height:100%;border:0;display:block;background:#000}
.cam-overlay-top{
  position:absolute;top:0;left:0;right:0;padding:14px 18px;
  background:linear-gradient(180deg, rgba(0,0,0,0.60) 0%, transparent 100%);
  display:flex;justify-content:space-between;align-items:center;pointer-events:none;z-index:2;
}
.cam-overlay-top .live-pill{margin:0;background:rgba(239,68,68,0.95);border-color:transparent;color:#fff}
.cam-overlay-top .live-pill::before{background:#fff}
.cam-overlay-top .cam-source{color:rgba(255,255,255,0.85);font-size:0.78rem;letter-spacing:0.04em;font-family:ui-monospace,monospace}
.cam-fallback{
  position:absolute;inset:0;display:none;align-items:center;justify-content:center;flex-direction:column;color:rgba(255,255,255,0.65);text-align:center;padding:40px;
}
.cam-card[data-fallback="true"] iframe{display:none}
.cam-card[data-fallback="true"] .cam-fallback{display:flex}
.cam-fallback h3{font-family:var(--font-display);color:#fff;font-size:1.4rem;font-weight:500;margin-bottom:6px}
.cam-fallback p{font-size:0.92rem;color:rgba(255,255,255,0.55)}

/* ============ Weather card (sidebar of broadcast) ============ */
.wx-card{
  background:linear-gradient(135deg, var(--white) 0%, #F4F0E5 100%);
  border-radius:24px;padding:28px;
  box-shadow:0 18px 40px rgba(11,26,58,0.10), 0 1px 0 rgba(255,255,255,0.5) inset;
  border:1px solid rgba(212,165,90,0.20);
  position:relative;overflow:hidden;
}
.wx-card::before{content:'';position:absolute;top:-30%;right:-20%;width:200px;height:200px;background:radial-gradient(circle, rgba(212,165,90,0.20) 0%, transparent 70%);pointer-events:none}
.wx-card .eyebrow{color:var(--gold-dark);margin-bottom:6px;font-size:0.68rem}
.wx-current-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}
.wx-temp{font-family:var(--font-display);font-size:3.6rem;font-weight:400;color:var(--ink);line-height:1;letter-spacing:-0.02em}
.wx-temp-unit{font-size:1.8rem;color:var(--gold-dark);vertical-align:top;margin-left:2px}
.wx-emoji{font-size:3rem;line-height:1}
.wx-condition{font-size:1rem;color:var(--text);font-weight:500;margin-bottom:4px;text-transform:capitalize}
.wx-feels{font-size:0.82rem;color:var(--text-muted)}

.wx-row{display:flex;align-items:center;gap:8px;font-size:0.85rem;color:var(--text-light);padding:8px 0;border-top:1px solid rgba(229,225,214,0.6)}
.wx-row:first-of-type{border-top:1px solid rgba(229,225,214,0.85)}
.wx-row strong{margin-left:auto;color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
.wx-row svg{width:14px;height:14px;color:var(--text-muted);flex-shrink:0}

.wx-skel{padding:8px 0;color:var(--text-muted);font-size:0.85rem;text-align:center}
.wx-source{margin-top:14px;padding-top:14px;border-top:1px solid rgba(229,225,214,0.85);font-size:0.72rem;color:var(--text-muted);text-align:center;letter-spacing:0.02em}
.wx-source a{color:var(--gold-dark);text-decoration:underline}

/* Wind compass */
.wx-compass{
  width:36px;height:36px;border-radius:50%;background:var(--pearl);
  display:inline-flex;align-items:center;justify-content:center;position:relative;flex-shrink:0;
  border:1px solid var(--line);
}
.wx-compass-arrow{
  width:2px;height:14px;background:var(--gold-dark);border-radius:2px;
  position:absolute;top:6px;left:50%;transform-origin:50% 12px;
  transform:translateX(-50%) rotate(0deg);transition:transform .8s var(--ease);
}
.wx-compass-arrow::before{content:'';position:absolute;top:-3px;left:-2px;border:3px solid transparent;border-bottom-color:var(--gold-dark)}

/* ============ Forecast strip ============ */
.bc-forecast{padding:32px 0 64px}
.bc-forecast h2{font-family:var(--font-display);font-size:1.6rem;font-weight:500;color:var(--ink);margin-bottom:18px}
.bc-forecast-grid{display:grid;grid-template-columns:repeat(6, 1fr);gap:10px}
@media(max-width:1100px){.bc-forecast-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.bc-forecast-grid{grid-template-columns:repeat(2,1fr);gap:8px}}
.fc-card{
  background:var(--white);border:1px solid var(--line);border-radius:18px;padding:18px 14px;text-align:center;
  transition:all .25s var(--ease);position:relative;
}
.fc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.fc-card[data-today="true"]{background:linear-gradient(135deg, var(--pearl) 0%, var(--sand) 100%);border-color:var(--gold)}
.fc-day{font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);font-weight:600;margin-bottom:6px}
.fc-date{font-family:var(--font-display);font-size:1.4rem;color:var(--ink);font-weight:500;line-height:1;margin-bottom:8px}
.fc-emoji{font-size:1.8rem;line-height:1;margin:8px 0}
.fc-cond{font-size:0.78rem;color:var(--text-light);margin-bottom:8px;min-height:32px;line-height:1.3}
.fc-temp{display:flex;align-items:center;justify-content:center;gap:6px;font-family:var(--font-display);font-size:1.05rem;color:var(--ink)}
.fc-temp .max{font-weight:600}
.fc-temp .sep{color:var(--text-muted)}
.fc-temp .min{color:var(--text-muted)}
.fc-meta{display:flex;justify-content:center;gap:10px;margin-top:8px;padding-top:8px;border-top:1px solid var(--line-soft, var(--line));font-size:0.72rem;color:var(--text-muted)}

/* ============ Marine card ============ */
.bc-marine{
  background:linear-gradient(135deg, #0B1A3A 0%, #1A2D5C 60%, #2D4A7A 100%);
  border-radius:24px;padding:28px;color:#fff;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  margin-bottom:48px;
  position:relative;overflow:hidden;
  box-shadow:0 18px 40px rgba(11,26,58,0.20);
}
.bc-marine::before{content:'';position:absolute;inset:0;background:
  radial-gradient(circle at 100% 0%, rgba(212,165,90,0.12) 0%, transparent 40%);}
@media(max-width:768px){.bc-marine{grid-template-columns:repeat(2,1fr)}}
.mar-item{position:relative}
.mar-label{font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.55);font-weight:600;margin-bottom:8px}
.mar-value{font-family:var(--font-display);font-size:2rem;color:#fff;font-weight:500;line-height:1}
.mar-value .unit{font-size:0.95rem;color:var(--gold-bright);font-family:var(--font-ui);font-weight:400;margin-left:3px}
.mar-meta{font-size:0.78rem;color:rgba(255,255,255,0.55);margin-top:6px}

/* ============ Windy embed ============ */
.windy-card{
  border-radius:24px;overflow:hidden;
  box-shadow:0 18px 40px rgba(11,26,58,0.10);
  border:1px solid var(--line);
  background:#0B1A3A;
  margin-bottom:48px;
}
.windy-card-head{padding:14px 22px;background:#fff;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.windy-card-head h3{font-family:var(--font-display);font-size:1.05rem;font-weight:500;color:var(--ink);margin:0}
.windy-card-head a{font-size:0.78rem;color:var(--text-muted);text-decoration:underline}
.windy-frame{aspect-ratio:16/9;width:100%;display:block;border:0}

/* ============ Compact home weather pill ============ */
.home-wx-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px 8px 8px;background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.18);border-radius:99px;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  color:rgba(255,255,255,0.92);font-size:0.85rem;font-weight:500;
  text-decoration:none;transition:all .25s var(--ease);
}
.home-wx-pill:hover{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.35);transform:translateY(-1px)}
.home-wx-pill .home-wx-emoji{font-size:1.2rem;line-height:1}
.home-wx-pill .home-wx-temp{font-family:var(--font-display);font-size:1.05rem;color:#fff}
.home-wx-pill .home-wx-sep{color:rgba(255,255,255,0.35)}
.home-wx-pill .home-wx-water{color:var(--gold-bright);font-size:0.78rem;letter-spacing:0.04em}
.home-wx-pill .home-wx-water::before{content:'🌊';margin-right:3px;font-size:0.9rem}

@media(max-width:560px){
  .bc-hero{padding:80px 0 24px}
  .wx-card{padding:22px}
  .wx-temp{font-size:2.8rem}
  .wx-emoji{font-size:2.4rem}
  .bc-marine{padding:22px;gap:16px}
  .mar-value{font-size:1.5rem}
}

/* =========================================================
   MOBILE BOTTOM TAB BAR — append to /assets/css/style.css
   ========================================================= */

.mob-bottom{
  display:none;
  position:fixed;left:0;right:0;bottom:0;z-index:1000;
  background:rgba(255,255,255,0.96);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-top:1px solid var(--line);
  box-shadow:0 -8px 24px rgba(11,26,58,0.08);
  padding:8px 6px calc(8px + env(safe-area-inset-bottom, 0px));
  justify-content:space-around;align-items:center;gap:4px;
}
.mob-bottom-tab{
  flex:1;min-width:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:6px 4px;border-radius:14px;
  font-family:var(--font-ui);font-size:0.65rem;font-weight:500;letter-spacing:0.02em;
  color:var(--text-muted);text-decoration:none;
  transition:all .25s var(--ease);
  -webkit-tap-highlight-color:rgba(212,165,90,0.20);
  position:relative;
}
.mob-bottom-tab svg{width:22px;height:22px;stroke-width:1.7}
.mob-bottom-tab span{display:block;line-height:1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.mob-bottom-tab.active{color:var(--ink)}
.mob-bottom-tab.active svg{stroke-width:2;color:var(--gold-dark)}
.mob-bottom-tab.active::before{
  content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  width:24px;height:3px;background:var(--gold);border-radius:0 0 3px 3px;
}

/* Center CTA tab — gold floating button */
.mob-bottom-tab--cta{
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);
  color:#fff !important;
  flex:0 0 auto;width:60px;height:60px;
  border-radius:50%;
  margin-top:-22px;
  box-shadow:0 12px 28px rgba(212,165,90,0.45), 0 0 0 4px #fff;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.mob-bottom-tab--cta svg{width:24px;height:24px;color:#fff;stroke-width:2}
.mob-bottom-tab--cta span{font-size:0.6rem;color:rgba(255,255,255,0.95);font-weight:600;margin-top:1px}
.mob-bottom-tab--cta::before{display:none !important}
.mob-bottom-tab--cta:active{transform:scale(0.96)}
.mob-bottom-tab--cta.active{background:linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 100%)}

/* Drawer trigger button — for secondary nav (replaces or extends hamburger) */
.mob-drawer-overlay{
  display:none;position:fixed;inset:0;background:rgba(11,26,58,0.55);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1100;
  opacity:0;transition:opacity .3s var(--ease);
}
.mob-drawer-overlay.show{display:block;opacity:1}

.mob-drawer{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:1101;
  background:#fff;border-radius:24px 24px 0 0;
  padding:14px 20px calc(20px + env(safe-area-inset-bottom, 0px));
  transform:translateY(100%);transition:transform .35s var(--ease);
  max-height:80vh;overflow-y:auto;
  box-shadow:0 -32px 64px rgba(11,26,58,0.30);
}
.mob-drawer.show{display:block;transform:translateY(0)}
.mob-drawer-handle{
  width:40px;height:4px;background:var(--line);border-radius:99px;
  margin:0 auto 16px;
}
.mob-drawer h3{
  font-family:var(--font-display);font-size:1.2rem;font-weight:500;color:var(--ink);
  margin-bottom:8px;letter-spacing:-0.01em;
}
.mob-drawer h3 + p{font-size:0.85rem;color:var(--text-muted);margin-bottom:18px}
.mob-drawer-list{display:flex;flex-direction:column;gap:2px;margin-bottom:10px}
.mob-drawer-item{
  display:flex;align-items:center;gap:14px;padding:14px 16px;
  border-radius:14px;color:var(--text);text-decoration:none;
  font-size:0.95rem;font-weight:500;
  transition:background .15s ease;
  -webkit-tap-highlight-color:transparent;
}
.mob-drawer-item:active{background:var(--pearl)}
.mob-drawer-item .ic{
  width:36px;height:36px;border-radius:10px;background:var(--pearl);
  color:var(--gold-dark);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.mob-drawer-item .ic svg{width:18px;height:18px}
.mob-drawer-item .lbl-block{flex:1;min-width:0}
.mob-drawer-item .lbl-block strong{display:block;color:var(--ink);font-weight:600;font-size:0.95rem}
.mob-drawer-item .lbl-block em{font-style:normal;font-size:0.78rem;color:var(--text-muted);margin-top:2px;display:block}
.mob-drawer-item .ic-chevron{color:var(--text-muted);flex-shrink:0}
.mob-drawer-item .ic-chevron svg{width:14px;height:14px}

.mob-drawer-divider{height:1px;background:var(--line-soft, #F3F4F6);margin:12px -8px}

.mob-drawer-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 12px 0;font-size:0.78rem;color:var(--text-muted);
}
.mob-drawer-footer a{color:var(--text);text-decoration:none}

/* Show on mobile only */
@media (max-width: 860px){
  .mob-bottom{display:flex}
  body{padding-bottom:80px}
  /* Hide existing top hamburger (drawer trigger via bottom-bar instead) */
  .nav-toggle{display:none !important}
  /* Also hide top header CTA "Забронировать" button — duplicates bottom CTA */
  .site-header .header-actions .btn-primary,
  .site-header .header-actions .btn-cta{display:none}
  /* Smaller header on mobile */
  .site-header{padding:10px 0}
  .site-header.scrolled{padding:8px 0}
  /* Hide top nav-links — entirely replaced by drawer */
  .site-nav .nav-links{display:none}
}

/* Don't show on print or admin */
body.has-sidebar .mob-bottom,
body.login-page .mob-bottom{display:none !important}
@media print{.mob-bottom,.mob-drawer,.mob-drawer-overlay{display:none !important}}


/* ===== SUP CTA (homepage) ===== */
.sup-cta-section{padding:96px 0;background:var(--bg)}
.sup-cta-card{display:grid;grid-template-columns:1fr 1.05fr;gap:0;background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.sup-cta-visual{position:relative;min-height:520px;background:url('/assets/img/gallery/g-3.jpg') center/cover no-repeat,linear-gradient(135deg,var(--ocean-deep),var(--ocean))}
.sup-cta-visual::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,26,58,0) 30%,rgba(11,26,58,0.5) 100%)}
.sup-cta-tag{position:absolute;top:22px;left:22px;z-index:2;background:var(--gold);color:var(--ink);font-size:0.72rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;padding:7px 14px;border-radius:var(--radius-full)}
.sup-cta-body{padding:56px 60px;display:flex;flex-direction:column;justify-content:center}
.sup-cta-body h2{margin:0 0 14px;font-family:var(--font-display);font-size:2.4rem;line-height:1.1;color:var(--ink)}
.sup-cta-body .subtitle{margin-bottom:26px;color:var(--text-light)}
.sup-cta-tariffs{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:28px;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sup-cta-tariff-name{font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);font-weight:600}
.sup-cta-tariff-price{font-family:var(--font-display);font-size:1.7rem;color:var(--ink);margin-top:6px}
.sup-cta-tariff-price span{font-family:var(--font-ui);font-size:0.85rem;color:var(--text-light);margin-left:6px;font-weight:400}
.sup-cta-actions{margin-bottom:18px}
.sup-cta-foot{display:flex;flex-wrap:wrap;gap:14px;color:var(--text-muted);font-size:0.85rem}
@media (max-width:960px){.sup-cta-card{grid-template-columns:1fr}.sup-cta-visual{min-height:240px}.sup-cta-body{padding:32px 28px}.sup-cta-body h2{font-size:1.9rem}}
@media (max-width:480px){.sup-cta-tariffs{grid-template-columns:1fr}}


/* ===== Account utility classes (LK) ===== */
.acc-meta{font-size:0.78rem;color:var(--text-muted)}
.acc-meta-sm{font-size:0.74rem;color:var(--text-muted)}
.acc-sub{font-size:0.82rem;color:var(--text-light)}
.acc-sub-pad{font-size:0.82rem;color:var(--text-light);margin-top:2px}
.acc-strong{color:var(--ink);font-weight:500}
.acc-check{display:flex;align-items:flex-start;gap:8px;cursor:pointer;font-size:0.86rem;color:var(--text-light)}
.acc-check input{margin-top:3px}
.acc-check-cb{margin-top:3px}
.acc-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:var(--ink);font-size:0.92rem}
.acc-mono-chip{background:var(--pearl);padding:1px 6px;border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.acc-row{padding:14px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.acc-row+.acc-row{border-top:1px solid var(--line)}
.acc-link-danger{background:none;border:0;color:var(--danger);font-size:0.74rem;cursor:pointer;text-decoration:underline;padding:0}
.acc-link-danger:hover{opacity:0.75}
.acc-span-all{grid-column:1/-1}
.acc-h-flex{display:flex;align-items:center;gap:8px}
.acc-h-flex-wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.acc-mb-sm{margin-bottom:8px}
.acc-mt-md{margin-top:14px}


/* ===== Public utilities (sup/login/broadcast) ===== */
.fz-7r{font-size:0.7rem}
.fz-74r{font-size:0.74rem}
.fz-78r{font-size:0.78rem}
.fz-82r{font-size:0.82rem}
.fz-86r{font-size:0.86rem}
.fz-92r{font-size:0.92rem}
.fz-1r{font-size:1rem}
.fz-105r{font-size:1.05rem}
.fz-12r{font-size:1.2rem}
.fz-17r{font-size:1.7rem}
.t-muted{color:var(--text-muted)}
.t-light{color:var(--text-light)}
.t-ink{color:var(--ink)}
.t-gold{color:var(--gold-dark)}
.t-danger{color:var(--danger)}

.acc-danger-zone{color:#991B1B}

.fz-85r{font-size:0.85rem}
.col-span-all{grid-column:1 / -1}
.is-hidden{display:none}
.no-margin{margin:0}
.t-ink{color:#0B1A3A}
.t-danger-hex{color:#EF4444}
.t-muted-hex{color:#9CA3AF}
.t-gold-hex{color:#A8823F}
.mb-16{margin-bottom:16px}
.mt-16-alt{margin-top:16px}
.pad-y-8{padding:8px 0}

/* ===== SUP week widget — Premium redesign ===== */
.sup-week-wrap{margin:32px 0 48px}
.sup-week{
  background:linear-gradient(135deg, #0B1A3A 0%, #1A2D5C 60%, #2D4A7A 100%);
  border-radius:24px;
  padding:36px 32px;
  color:#F8F4ED;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.sup-week::before{
  content:'';position:absolute;top:-40%;right:-10%;width:380px;height:380px;
  background:radial-gradient(circle, rgba(212,165,90,0.18) 0%, transparent 65%);
  pointer-events:none;z-index:0;
}
.sup-week > *{position:relative;z-index:1}

.sup-week-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:32px;
  margin-bottom:28px;flex-wrap:wrap;padding-bottom:20px;
  border-bottom:1px solid rgba(248,244,237,0.10);
}
.sup-week-head-title .eyebrow{color:var(--gold-bright);margin-bottom:8px}
.sup-week h2{
  font-family:var(--font-display);font-weight:500;font-size:1.7rem;
  color:#F8F4ED;letter-spacing:-0.01em;margin:0;line-height:1.15;
}
.sup-week-sub{
  color:rgba(248,244,237,0.62);font-size:0.86rem;
  margin:8px 0 0;max-width:520px;line-height:1.5;
}

.sup-week-legend{display:flex;gap:18px;flex-wrap:wrap;font-size:0.78rem;color:rgba(248,244,237,0.7)}
.sw-leg{display:inline-flex;align-items:center;gap:6px}
.sw-leg::before{content:'';width:10px;height:10px;border-radius:50%;display:inline-block}
.sw-leg--green::before{background:#10B981;box-shadow:0 0 8px rgba(16,185,129,0.5)}
.sw-leg--yellow::before{background:#F59E0B;box-shadow:0 0 8px rgba(245,158,11,0.5)}
.sw-leg--red::before{background:#EF4444;box-shadow:0 0 8px rgba(239,68,68,0.5)}
.sw-leg--night::before{background:#374151;border:1px solid rgba(255,255,255,0.15)}

.sup-week-table{
  display:flex;flex-direction:column;gap:8px;
}

.sw-row{
  display:grid;
  grid-template-columns:120px 1fr 260px;
  gap:24px;align-items:center;
  padding:16px 20px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  transition:all 0.25s var(--ease);
}
.sw-row:hover{background:rgba(255,255,255,0.06);border-color:rgba(212,165,90,0.25)}
.sw-row--today{
  background:linear-gradient(135deg, rgba(212,165,90,0.10), rgba(212,165,90,0.04));
  border-color:rgba(212,165,90,0.40);
  box-shadow:0 0 0 1px rgba(212,165,90,0.15) inset;
}
.sw-row--head{
  background:transparent;border:none;padding:0 20px 8px;
  font-size:0.68rem;letter-spacing:0.20em;text-transform:uppercase;
  color:rgba(248,244,237,0.45);font-weight:600;
}

.sw-day-cell{display:flex;flex-direction:column;gap:2px}
.sw-day-name{
  font-family:var(--font-display);font-size:1.25rem;font-weight:500;
  color:#F8F4ED;line-height:1;
}
.sw-day-name--today{color:var(--gold-bright)}
.sw-day-date{font-size:0.78rem;color:rgba(248,244,237,0.50);font-variant-numeric:tabular-nums;letter-spacing:0.04em}
.sw-day-badge{
  display:inline-block;margin-top:6px;
  background:var(--gold);color:var(--ink);
  font-size:0.62rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  padding:2px 8px;border-radius:99px;
}

.sw-cells{
  display:grid;grid-template-columns:repeat(6, 1fr);gap:6px;
  height:48px;
}
.sw-cell{
  position:relative;
  border-radius:8px;
  background:#1f2937;
  cursor:help;
  transition:transform 0.2s var(--ease), box-shadow 0.2s var(--ease);
  overflow:hidden;
}
.sw-cell::after{
  content:attr(data-hour);
  position:absolute;bottom:3px;left:50%;transform:translateX(-50%);
  font-size:0.62rem;color:rgba(255,255,255,0.55);font-weight:600;
  font-variant-numeric:tabular-nums;
  letter-spacing:0.02em;
}
.sw-cell:hover{transform:translateY(-2px);box-shadow:0 6px 14px rgba(0,0,0,0.25)}
.sw-cell--green{background:linear-gradient(180deg, #10B981, #047857)}
.sw-cell--green::after{color:rgba(255,255,255,0.85)}
.sw-cell--yellow{background:linear-gradient(180deg, #F59E0B, #B45309)}
.sw-cell--yellow::after{color:rgba(255,255,255,0.85)}
.sw-cell--red{background:linear-gradient(180deg, #EF4444, #991B1B)}
.sw-cell--red::after{color:rgba(255,255,255,0.85)}
.sw-cell--night{
  background:repeating-linear-gradient(45deg, #1f2937, #1f2937 5px, #2d3748 5px, #2d3748 10px);
  opacity:0.5;cursor:default;
}
.sw-cell--night::after{display:none}

.sw-summary-cell{
  display:flex;flex-direction:column;gap:6px;align-items:flex-start;
}
.sw-window-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px 5px 10px;
  border-radius:99px;
  font-size:0.78rem;font-weight:500;
  font-family:ui-monospace, SFMono-Regular, Menlo, monospace;
  letter-spacing:0.02em;
  border:1px solid;
  white-space:nowrap;
}
.sw-window-pill::before{content:'';width:6px;height:6px;border-radius:50%;display:inline-block}
.sw-window-pill small{
  font-size:0.7rem;font-weight:400;opacity:0.75;
  font-family:var(--font-ui);margin-left:2px;
}
.sw-window-pill--green{
  background:rgba(16,185,129,0.14);color:#A7F3D0;
  border-color:rgba(16,185,129,0.45);
}
.sw-window-pill--green::before{background:#10B981;box-shadow:0 0 6px rgba(16,185,129,0.6)}
.sw-window-pill--yellow{
  background:rgba(245,158,11,0.14);color:#FCD34D;
  border-color:rgba(245,158,11,0.45);
}
.sw-window-pill--yellow::before{background:#F59E0B;box-shadow:0 0 6px rgba(245,158,11,0.5)}
.sw-no-window{
  color:rgba(248,244,237,0.40);font-size:0.82rem;
  font-style:italic;letter-spacing:0.04em;
}

.sup-week-foot{
  margin-top:24px;padding-top:18px;
  border-top:1px solid rgba(248,244,237,0.10);
  font-size:0.74rem;color:rgba(248,244,237,0.45);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.sup-week-foot a{color:var(--gold-bright);text-decoration:none;border-bottom:1px solid rgba(212,165,90,0.3)}
.sup-week-foot a:hover{border-bottom-color:var(--gold-bright)}

.sw-loading,.sw-error{
  padding:48px 24px;text-align:center;font-size:0.95rem;
  color:rgba(248,244,237,0.55);
  background:rgba(255,255,255,0.03);border-radius:14px;
  border:1px dashed rgba(255,255,255,0.10);
}
.sw-error{color:#FCA5A5;border-color:rgba(239,68,68,0.30)}

/* Tablet */
@media(max-width:900px){
  .sup-week{padding:28px 22px}
  .sw-row{grid-template-columns:90px 1fr;gap:14px;padding:14px 16px}
  .sw-summary-cell{grid-column:1 / -1;flex-direction:row;flex-wrap:wrap;padding-top:8px;border-top:1px dashed rgba(255,255,255,0.08)}
  .sw-row--head .sw-summary-cell{display:none}
  .sw-row--head{padding:0 16px 4px}
  .sw-day-name{font-size:1.05rem}
}

/* Mobile */
@media(max-width:560px){
  .sup-week{padding:22px 16px;border-radius:18px}
  .sup-week h2{font-size:1.25rem}
  .sup-week-head{margin-bottom:20px;padding-bottom:16px}
  .sw-row{padding:12px 12px;border-radius:10px}
  .sw-cells{height:40px;gap:4px}
  .sw-cell{border-radius:6px}
  .sw-cell::after{font-size:0.55rem;bottom:2px}
  .sw-window-pill{font-size:0.74rem;padding:4px 10px 4px 9px}
  .sup-week-legend{gap:12px;font-size:0.72rem}
}


/* Hour scale colour indication */
.sw-cells--scale{height:auto;align-items:stretch}
.sw-hour-mark{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:6px 4px;border-radius:8px;cursor:help;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.06);
  transition:all 0.2s var(--ease);
}
.sw-hour-mark:hover{transform:translateY(-1px);border-color:rgba(212,165,90,0.30);background:rgba(255,255,255,0.06)}
.sw-hour-label{
  font-size:0.7rem;font-weight:700;letter-spacing:0.08em;
  font-variant-numeric:tabular-nums;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  color:rgba(248,244,237,0.85);
}
.sw-hour-mark--green .sw-hour-label{color:#A7F3D0}
.sw-hour-mark--yellow .sw-hour-label{color:#FCD34D}
.sw-hour-mark--red .sw-hour-label{color:#FCA5A5}

.sw-hour-bar{
  display:flex;width:100%;height:5px;border-radius:99px;overflow:hidden;
  background:rgba(255,255,255,0.06);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.04);
}
.sw-hour-bar-seg{display:block;height:100%}
.sw-hour-bar-seg--green{background:linear-gradient(90deg,#10B981,#34D399)}
.sw-hour-bar-seg--yellow{background:linear-gradient(90deg,#F59E0B,#FBBF24)}
.sw-hour-bar-seg--red{background:linear-gradient(90deg,#EF4444,#F87171)}

/* Tighter on mobile */
@media(max-width:560px){
  .sw-hour-mark{padding:5px 2px;gap:4px}
  .sw-hour-label{font-size:0.62rem;letter-spacing:0.04em}
  .sw-hour-bar{height:4px}
}

/* ============================================================
   OBJECT DETAIL PAGE — premium redesign (object.php)
   ============================================================ */

/* Cinematic hero with photo background */
.obj-hero{
  position:relative;
  min-height:540px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:120px 0 56px;
  overflow:hidden;
  color:#fff;
  isolation:isolate;
}
.obj-hero-img{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#0B1A3A 0%,#1A2D5C 60%,#2D4A7A 100%) center/cover no-repeat;
  z-index:-2;
  transition:background-image 0.4s var(--ease);
}
.obj-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(11,26,58,0.35) 0%, rgba(11,26,58,0.55) 60%, rgba(11,26,58,0.85) 100%);
  z-index:-1;
}
.obj-hero-inner{position:relative;z-index:1}

.obj-breadcrumb{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:0.82rem;letter-spacing:0.04em;
  color:rgba(255,255,255,0.75);
  margin-bottom:16px;
}
.obj-breadcrumb a{color:rgba(255,255,255,0.75);text-decoration:none;border-bottom:1px solid transparent;transition:all 0.2s}
.obj-breadcrumb a:hover{color:#fff;border-bottom-color:var(--gold-bright)}
.obj-bc-sep{color:rgba(255,255,255,0.40)}
.obj-bc-current{color:#fff;font-weight:500}

.eyebrow--light{color:var(--gold-bright)}

.obj-hero-title-row{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  margin:8px 0 18px;
}
.obj-title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(1.9rem, 4.5vw, 3.2rem);
  line-height:1.05;letter-spacing:-0.02em;
  color:#fff;margin:0;
  text-shadow:0 2px 24px rgba(0,0,0,0.35);
}

.obj-fav{
  flex-shrink:0;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,0.10);
  border:1.5px solid rgba(255,255,255,0.30);
  color:#fff;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:all 0.25s var(--ease);
}
.obj-fav:hover{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.55);transform:scale(1.05)}
.obj-fav-icon{font-size:1.5rem;line-height:1}
.obj-fav--on{background:rgba(239,68,68,0.85);border-color:rgba(239,68,68,1);box-shadow:0 6px 18px rgba(239,68,68,0.40)}
.obj-fav--on:hover{background:rgba(239,68,68,1)}

.obj-hero-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.obj-meta-chip{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:99px;
  padding:7px 14px;
  font-size:0.82rem;font-weight:500;
  color:#fff;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.obj-meta-chip--accent{
  background:rgba(212,165,90,0.20);
  border-color:rgba(212,165,90,0.50);
  color:var(--gold-bright);
}

.obj-hero-scroll-hint{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:0.7rem;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(255,255,255,0.55);
}
.obj-hero-scroll-line{width:1px;height:36px;background:linear-gradient(180deg,rgba(255,255,255,0.5),transparent)}

/* Content layout */
.obj-content-section{padding:64px 0 96px;background:var(--bg)}
.obj-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 360px;
  gap:48px;
  align-items:flex-start;
}
.obj-main{display:flex;flex-direction:column;gap:48px;min-width:0}
.obj-sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:24px}

/* Gallery */
.obj-gallery{display:flex;flex-direction:column;gap:12px}
.obj-gallery-main{
  position:relative;
  width:100%;aspect-ratio:16/10;
  background:linear-gradient(135deg,#0B1A3A,#1A2D5C) center/cover no-repeat;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.obj-gallery-placeholder{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,0.55);
  font-size:0.92rem;letter-spacing:0.04em;
}
.obj-gallery-thumbs{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(86px, 1fr));
  gap:10px;
}
.obj-gallery-thumb,.gallery-thumb{
  aspect-ratio:1/1;
  background:#1A2D5C center/cover no-repeat;
  border-radius:10px;
  border:2px solid transparent;
  cursor:pointer;
  transition:all 0.2s var(--ease);
  opacity:0.78;
  padding:0;
}
.obj-gallery-thumb:hover,.gallery-thumb:hover{opacity:1;transform:translateY(-2px)}
.obj-gallery-thumb.active,.gallery-thumb.active{
  opacity:1;border-color:var(--gold);
  box-shadow:0 4px 14px rgba(212,165,90,0.30);
}

/* Sections */
.obj-block{display:flex;flex-direction:column;gap:14px}
.obj-block .eyebrow{margin-bottom:0}
.obj-h2{
  font-family:var(--font-display);font-weight:500;
  font-size:1.7rem;line-height:1.15;
  color:var(--ink);margin:0;
  letter-spacing:-0.01em;
}
.obj-prose{
  font-size:1rem;line-height:1.65;color:var(--text);
  white-space:pre-line;
}
.obj-prose strong{color:var(--ink)}

/* Features grid (overrides homepage chips slightly) */
.obj-features{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:12px;
}
.obj-features .feature-chip{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:14px;
  transition:all 0.2s var(--ease);
}
.obj-features .feature-chip:hover{
  border-color:var(--gold);
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(11,26,58,0.06);
}
.obj-features .feature-icon{
  width:36px;height:36px;flex-shrink:0;
  background:linear-gradient(135deg, var(--pearl), var(--sand));
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}
.obj-features .feature-icon img{width:20px;height:20px;object-fit:contain}
.obj-features .feature-label{font-size:0.92rem;font-weight:500;color:var(--ink)}
.obj-features-loading,.obj-tariffs-loading{
  color:var(--text-muted);font-size:0.9rem;font-style:italic;
}
.no-features,.no-tariffs{color:var(--text-muted);font-size:0.92rem;font-style:italic}

/* Tariffs table */
.obj-tariffs{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.tariff-table{
  width:100%;border-collapse:collapse;
  font-size:0.95rem;
}
.tariff-table thead{
  background:linear-gradient(135deg,var(--pearl),var(--sand));
}
.tariff-table th{
  padding:14px 18px;text-align:left;
  font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--text-muted);font-weight:600;
}
.tariff-table th:last-child{text-align:right}
.tariff-table td{
  padding:16px 18px;
  border-top:1px solid var(--line);
  vertical-align:middle;
  color:var(--ink);
}
.tariff-table td:last-child{text-align:right}
.tariff-season{
  font-family:var(--font-display);
  font-weight:500;font-size:1.05rem;
  color:var(--ink);
  background:rgba(212,165,90,0.04);
  border-right:1px solid var(--line);
}
.tariff-daytype{color:var(--text-light)}
.tariff-hour{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.tariff-day{color:var(--text-light);font-variant-numeric:tabular-nums}

/* Rules list */
.obj-rules{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:12px;
}
.obj-rules li{
  position:relative;
  padding:14px 18px 14px 50px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:12px;
  font-size:0.95rem;line-height:1.55;color:var(--text);
}
.obj-rules li::before{
  content:'!';
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:24px;height:24px;
  background:var(--gold);color:var(--ink);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:0.78rem;
  font-family:var(--font-display);
}
.obj-rules strong{color:var(--danger);font-weight:600}

/* Booking sidebar card */
.obj-booking-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:20px;
  padding:28px;
  box-shadow:0 18px 40px rgba(11,26,58,0.08), var(--shadow-sm);
  position:relative;
}
.obj-booking-card::before{
  content:'';position:absolute;top:0;left:24px;right:24px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.obj-bc-eyebrow{
  font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold-dark);font-weight:600;margin-bottom:8px;
}
.obj-bc-price{
  display:flex;align-items:baseline;gap:6px;
  margin-bottom:20px;
}
.obj-bc-price-label{color:var(--text-muted);font-size:0.85rem}
.obj-bc-price-value{
  font-family:var(--font-display);font-weight:500;
  font-size:2.4rem;color:var(--ink);
  letter-spacing:-0.02em;line-height:1;
}
.obj-bc-price-unit{
  color:var(--text-light);font-size:1.1rem;font-weight:500;
}
.obj-bc-price-unit small{font-size:0.78rem;color:var(--text-muted);font-weight:400}

.obj-bc-divider{height:1px;background:var(--line);margin:0 -8px 20px}

.obj-bc-info{margin:0 0 22px;display:flex;flex-direction:column;gap:10px}
.obj-bc-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:6px 0}
.obj-bc-row dt{color:var(--text-muted);font-size:0.85rem;margin:0}
.obj-bc-row dd{margin:0;color:var(--ink);font-weight:500;font-size:0.92rem;text-align:right}

.obj-bc-btn{width:100%;justify-content:center;font-size:0.95rem;padding:14px 22px}

.obj-bc-note{
  margin:14px 0 0;text-align:center;
  font-size:0.75rem;color:var(--text-muted);
  line-height:1.5;
}

/* Sidebar secondary CTA */
.obj-sidebar-cta{
  background:linear-gradient(135deg, var(--pearl), var(--sand));
  border-radius:16px;
  padding:22px;
  text-align:center;
  border:1px solid var(--line);
}
.obj-sidebar-cta-title{
  font-family:var(--font-display);
  font-size:1rem;font-weight:500;color:var(--ink);
  margin:0 0 8px;
}
.obj-sidebar-cta-link{
  display:inline-block;
  font-size:1.15rem;font-weight:600;
  color:var(--ink);text-decoration:none;
  border-bottom:2px solid var(--gold);
  padding-bottom:2px;
  font-variant-numeric:tabular-nums;
  letter-spacing:0.02em;
}
.obj-sidebar-cta-link:hover{color:var(--gold-dark)}
.obj-sidebar-cta-hint{
  margin:10px 0 0;font-size:0.78rem;color:var(--text-muted);
}

/* Mobile sticky CTA bar */
.obj-mobile-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  background:var(--white);
  border-top:1px solid var(--line);
  padding:14px 18px;
  z-index:90;
  box-shadow:0 -8px 24px rgba(11,26,58,0.10);
  align-items:center;justify-content:space-between;gap:14px;
}
.obj-mobile-cta-price{display:flex;align-items:baseline;gap:4px;font-size:0.86rem;color:var(--text-light)}
.obj-mobile-cta-from{color:var(--text-muted);font-size:0.78rem}
.obj-mobile-cta-price strong{font-family:var(--font-display);font-size:1.4rem;font-weight:500;color:var(--ink);letter-spacing:-0.01em}
.obj-mobile-cta-unit{color:var(--text-muted);font-size:0.78rem}
.obj-mobile-cta-btn{padding:12px 22px;font-size:0.9rem;flex-shrink:0}

/* Responsive */
@media(max-width:980px){
  .obj-layout{grid-template-columns:1fr;gap:36px}
  .obj-sidebar{position:static;order:-1}
  .obj-booking-card{padding:24px}
  .obj-sidebar-cta{display:none}
}
@media(max-width:768px){
  .obj-hero{min-height:420px;padding:90px 0 44px}
  .obj-hero-scroll-hint{display:none}
  .obj-content-section{padding:36px 0 120px}
  .obj-main{gap:36px}
  .obj-h2{font-size:1.35rem}
  .obj-mobile-cta{display:flex}
  body{padding-bottom:80px}
  .obj-features{grid-template-columns:repeat(2, 1fr)}
  .obj-features .feature-chip{padding:10px 12px}
  .obj-features .feature-icon{width:30px;height:30px}
  .obj-features .feature-label{font-size:0.82rem}
  .tariff-table th,.tariff-table td{padding:12px 12px;font-size:0.85rem}
  .obj-bc-price-value{font-size:2rem}
}
@media(max-width:480px){
  .obj-gallery-thumbs{grid-template-columns:repeat(4, 1fr)}
  .obj-features{grid-template-columns:1fr}
}
