@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap');

/* ════════════════════════════════════════════
   THEME SYSTEM — Light (default) & Dark
   Toggle adds [data-theme="dark"] to <html>
════════════════════════════════════════════ */
:root {
  --teal:        #09454b;
  --teal-light:  #0d5c65;
  --teal-pale:   #e8f4f5;
  --orange:      #DC6739;
  --orange-pale: #fdf0ea;
  --sand:        #C8B89A;

  /* LIGHT THEME (default) */
  --bg:          #faf7f2;
  --bg-alt:      #ffffff;
  --bg-sunken:   #f0ebe1;
  --surface:     #ffffff;
  --text:        #1a1a1a;
  --text-mid:    #4a4a4a;
  --text-soft:   #7a7268;
  --border:      #e8e2d9;
  --border-mid:  #d4cec4;
  --nav-bg:      rgba(250,247,242,0.96);
  --hero-overlay: linear-gradient(105deg,rgba(9,69,75,0.88) 0%,rgba(20,21,22,0.55) 60%,rgba(20,21,22,0.15) 100%);
  --footer-bg:   #161412;
  --footer-text: rgba(255,255,255,0.45);
  --logo-icon:   url('../images/logo-icon.png');
  --shadow:      0 1px 0 rgba(0,0,0,0.04);

  --font-sans:  'Outfit', sans-serif;
  --ease:       cubic-bezier(0.16,1,0.3,1);
}

[data-theme="dark"] {
  --bg:          #15171a;
  --bg-alt:      #1c1f23;
  --bg-sunken:   #101214;
  --surface:     #1c1f23;
  --text:        #f3f0ea;
  --text-mid:    #c7c2b8;
  --text-soft:   #8d877c;
  --border:      #2b2e33;
  --border-mid:  #3a3d42;
  --nav-bg:      rgba(21,23,26,0.92);
  --hero-overlay: linear-gradient(105deg,rgba(9,69,75,0.92) 0%,rgba(15,17,20,0.75) 60%,rgba(15,17,20,0.35) 100%);
  --footer-bg:   #0c0d0f;
  --footer-text: rgba(255,255,255,0.4);
  --logo-icon:   url('../images/logo-icon-white.png');
  --shadow:      0 1px 0 rgba(0,0,0,0.3);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-sans);font-weight:400;font-size:16px;line-height:1.7;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background 0.35s ease,color 0.35s ease;}
img{display:block;width:100%;height:100%;object-fit:cover;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
button{cursor:pointer;font-family:var(--font-sans);}

/* ─── TYPE SCALE (Outfit everywhere, weight does the talking) ─── */
.label{font-size:11px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;}
.label--teal{color:var(--teal);}
.label--orange{color:var(--orange);}

/* ─── THEME TOGGLE ─── */
.theme-toggle{display:flex;align-items:center;gap:8px;background:var(--bg-sunken);border:1px solid var(--border-mid);border-radius:20px;padding:4px;cursor:pointer;width:60px;height:30px;position:relative;transition:background 0.3s;}
.theme-toggle__knob{width:22px;height:22px;border-radius:50%;background:var(--teal);display:flex;align-items:center;justify-content:center;transition:transform 0.35s var(--ease),background 0.3s;position:absolute;left:4px;top:3px;}
[data-theme="dark"] .theme-toggle__knob{transform:translateX(28px);background:var(--orange);}
.theme-toggle__icon{width:13px;height:13px;color:white;}
.theme-toggle__icon.sun{display:block;}
.theme-toggle__icon.moon{display:none;}
[data-theme="dark"] .theme-toggle__icon.sun{display:none;}
[data-theme="dark"] .theme-toggle__icon.moon{display:block;}

/* ─── NAV ───
   FIXED THEME: the header always uses a solid, dark graphite
   background with light text — on every page, every scroll
   position, and in both light/dark site modes. It does NOT
   adapt to the hero image or page background. This guarantees
   the logo and links are always legible. ─── */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;height:76px;padding:0 60px;display:flex;align-items:center;justify-content:space-between;background:#181a1d;border-bottom:1px solid rgba(255,255,255,0.08);box-shadow:0 1px 0 rgba(0,0,0,0.25);}
.nav__logo{display:flex;align-items:center;gap:12px;}
.nav__icon{width:42px;height:42px;flex-shrink:0;object-fit:contain;}
.nav__name{font-size:20px;font-weight:600;letter-spacing:0.01em;line-height:1;color:#f3f0ea;}
.nav__name span{color:var(--orange);}
.nav__studio{font-size:8px;font-weight:400;letter-spacing:0.3em;text-transform:uppercase;color:#8d877c;line-height:1;margin-top:2px;}
.nav__links{display:flex;align-items:center;gap:32px;}
.nav__link{font-size:14px;font-weight:400;color:#c7c2b8;letter-spacing:0.02em;transition:color 0.2s;position:relative;}
.nav__link::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--orange);transition:width 0.3s var(--ease);}
.nav__link:hover{color:#f3f0ea;}
.nav__link:hover::after{width:100%;}
.nav__link.active{color:var(--orange);}
.nav__link.active::after{width:100%;background:var(--orange);}
.nav__cta{font-size:11px;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:9px 22px;background:var(--orange);color:white;border-radius:2px;transition:background 0.2s;}
.nav__cta:hover{background:#c55a2f;}
.nav__right{display:flex;align-items:center;gap:24px;}
.nav__hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;}
.nav__hamburger span{width:22px;height:1.5px;background:#f3f0ea;display:block;transition:all 0.3s;}

/* ─── HERO ALWAYS DARK (consistent — fixes "mixed" feel) ─── */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;overflow:hidden;background:#15171a;}
.hero__bg{position:absolute;inset:0;}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:0.4;}
.hero__overlay{position:absolute;inset:0;background:var(--hero-overlay);}
.hero__content{position:relative;z-index:2;padding:0 60px;max-width:820px;}
.hero__kicker{display:flex;align-items:center;gap:14px;margin-bottom:24px;}
.hero__kicker-line{width:40px;height:1px;background:var(--orange);}
.hero__kicker span{font-size:12px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.65);}
.hero__headline{font-family:var(--font-sans);font-size:clamp(32px,6vw,76px);font-weight:600;letter-spacing:-0.01em;color:white;line-height:1.05;margin-bottom:24px;}
.hero__headline em{font-style:normal;color:var(--orange);}
.hero__sub{font-size:17px;font-weight:300;color:rgba(255,255,255,0.72);line-height:1.75;max-width:520px;margin-bottom:40px;}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap;}
.hero__scroll{position:absolute;right:60px;bottom:56px;z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;}
.hero__scroll-line{width:1px;height:48px;background:rgba(255,255,255,0.3);animation:scrollAnim 2.2s ease-in-out infinite;}
.hero__scroll span{font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.4);writing-mode:vertical-lr;}
@keyframes scrollAnim{0%{opacity:0.2;transform:scaleY(0.5);transform-origin:top;}60%{opacity:1;transform:scaleY(1);}100%{opacity:0.2;}}

/* ─── BTN ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:0.11em;text-transform:uppercase;border-radius:4px;transition:all 0.25s var(--ease);border:1px solid transparent;outline:none;cursor:pointer;height:48px;padding:0 32px;box-sizing:border-box;text-align:center;white-space:nowrap;}
.btn--teal{background:var(--teal);color:white;border-color:var(--teal);}
.btn--teal:hover{background:var(--teal-light);border-color:var(--teal-light);transform:translateY(-1px);}
.btn--orange{background:var(--orange);color:white;border-color:var(--orange);}
.btn--orange:hover{background:#c55a2f;border-color:#c55a2f;transform:translateY(-1px);}
.btn--outline-teal{background:transparent;color:var(--teal);border-color:var(--teal);}
.btn--outline-teal:hover{background:var(--teal);color:white;border-color:var(--teal);}
[data-theme="dark"] .btn--outline-teal{color:var(--text);border-color:var(--border-mid);}
[data-theme="dark"] .btn--outline-teal:hover{background:var(--teal);border-color:var(--teal);color:white;}
.btn--outline-white{background:transparent;color:white;border-color:rgba(255,255,255,0.45);}
.btn--outline-white:hover{border-color:white;background:rgba(255,255,255,0.08);transform:translateY(-1px);}
.btn--white{background:white;color:var(--teal);border-color:white;}
.btn--white:hover{opacity:0.9;transform:translateY(-1px);}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--border-mid);}
.btn--ghost:hover{border-color:var(--teal);color:var(--teal);}
.btn--sm{height:34px;padding:0 16px;font-size:10px;}
.btn--danger{background:#b3402f;color:white;border-color:#b3402f;height:34px;padding:0 16px;font-size:10px;}
.btn--danger:hover{background:#8f3326;border-color:#8f3326;}

/* ─── SECTION ─── */
.section{padding:clamp(56px, 8vw, 100px) clamp(20px, 4.5vw, 60px);}
.section--bg{background:var(--bg);}
.section--alt{background:var(--bg-alt);}
.section--sunken{background:var(--bg-sunken);}
.section__eyebrow{font-size:11px;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--teal);margin-bottom:12px;}
[data-theme="dark"] .section__eyebrow{color:var(--orange);}
.section__title{font-family:var(--font-sans);font-weight:600;letter-spacing:-0.01em;font-size:clamp(26px,3.6vw,50px);line-height:1.15;color:var(--text);margin-bottom:16px;}
.section__title em{font-style:normal;color:var(--teal);}
[data-theme="dark"] .section__title em{color:var(--orange);}
.section__body{font-size:16px;font-weight:300;color:var(--text-mid);line-height:1.9;max-width:520px;letter-spacing:0.01em;}
.section__header{margin-bottom:64px;}
.section__header--center{text-align:center;}
.section__header--center .section__body{margin:0 auto;}

/* ─── STATS BAR ─── */
.statsbar{background:var(--bg-alt);border-bottom:1px solid var(--border);padding:0 60px;display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:28px 32px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:3px;}
.stat:first-child{padding-left:0;}
.stat:last-child{border-right:none;}
.stat__n{font-family:var(--font-sans);font-size:44px;font-weight:700;color:var(--teal);line-height:1;}
[data-theme="dark"] .stat__n{color:var(--orange);}
.stat__n sup{font-size:18px;}
.stat__l{font-size:13px;color:var(--text-soft);letter-spacing:0.04em;}

/* ─── PAGE HERO (interior pages) — always dark teal ─── */
.page-hero{background:var(--teal);padding:140px 60px 80px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;right:-80px;top:-80px;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,0.04);}
.page-hero__label{font-size:10px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:12px;}
.page-hero__title{font-family:var(--font-sans);font-size:clamp(28px,4.4vw,60px);font-weight:600;letter-spacing:-0.01em;color:white;line-height:1.1;margin-bottom:16px;max-width:900px;}
.page-hero__title em{font-style:normal;color:var(--orange);}
.page-hero__sub{font-size:17px;font-weight:300;color:rgba(255,255,255,0.68);line-height:1.75;max-width:560px;}

/* Portfolio page hero — same box model, plus background photo (was missing — caused horizontal overflow) */
.portfolio-page-hero{position:relative;overflow:hidden;padding:140px 60px 80px;background:var(--teal);}
.portfolio-page-hero__bg{position:absolute;inset:0;width:100%;height:100%;}
.portfolio-page-hero__bg img{width:100%;height:100%;object-fit:cover;display:block;}
.portfolio-page-hero__overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(9,69,75,0.92) 0%,rgba(15,17,20,0.78) 55%,rgba(15,17,20,0.5) 100%);}
.portfolio-page-hero__content{position:relative;z-index:2;max-width:900px;}

/* ─── SERVICES GRID ─── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.svc{background:var(--bg-alt);padding:52px 40px;position:relative;overflow:hidden;transition:background 0.3s var(--ease);}
.svc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform 0.4s var(--ease);}
[data-theme="dark"] .svc::after{background:var(--orange);}
.svc:hover{background:var(--bg);}
.svc:hover::after{transform:scaleX(1);}
.svc__num{font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--orange);margin-bottom:20px;display:block;}
.svc__icon{width:44px;height:44px;margin-bottom:20px;color:var(--teal);}
[data-theme="dark"] .svc__icon{color:var(--orange);}
.svc__title{font-size:19px;font-weight:500;color:var(--text);margin-bottom:10px;letter-spacing:0.01em;}
.svc__desc{font-size:15px;font-weight:300;color:var(--text-soft);line-height:1.85;}
.svc__tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:20px;}
.svc__tag{font-size:9px;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:3px 9px;border:1px solid var(--border-mid);color:var(--text-soft);border-radius:1px;}

/* ─── SERVICE DETAIL PAGE ─── */
.svc-detail{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;padding:72px 0;border-bottom:1px solid var(--border);}
.svc-detail:last-child{border-bottom:none;}
.svc-detail--reverse .svc-detail__img{order:2;}
.svc-detail--reverse .svc-detail__content{order:1;}
.svc-detail__img{height:420px;border-radius:2px;overflow:hidden;}
.svc-detail__num{font-family:var(--font-sans);font-size:42px;font-weight:700;color:var(--border-mid);line-height:1;margin-bottom:-6px;}
.svc-detail__title{font-size:26px;font-weight:600;color:var(--text);margin-bottom:14px;line-height:1.3;}
.svc-detail__desc{font-size:16px;font-weight:300;color:var(--text-mid);line-height:2.0;margin-bottom:24px;}
.svc-detail__list{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;}
.svc-detail__item{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--text-mid);}
.svc-detail__dot{width:6px;height:6px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:7px;}
[data-theme="dark"] .svc-detail__dot{background:var(--orange);}

/* ─── HOME PORTFOLIO PREVIEW ─── */
.portfolio-grid-home{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:240px;gap:6px;margin-bottom:36px;}
.pitem{position:relative;overflow:hidden;cursor:pointer;}
/* Row 1: hero image (8 cols, 2 rows tall) + tall side image (4 cols, 2 rows tall) */
.pitem:nth-child(1){grid-column:span 8;grid-row:span 2;}
.pitem:nth-child(2){grid-column:span 4;grid-row:span 2;}
/* Row 3: three equal columns */
.pitem:nth-child(3){grid-column:span 4;}
.pitem:nth-child(4){grid-column:span 4;}
.pitem:nth-child(5){grid-column:span 4;}
/* Row 4: three equal columns */
.pitem:nth-child(6){grid-column:span 4;}
.pitem:nth-child(7){grid-column:span 4;}
.pitem:nth-child(8){grid-column:span 4;}
.pitem__img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease);}
.pitem:hover .pitem__img{transform:scale(1.05);}
.pitem__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,69,75,0.85) 0%,transparent 55%);opacity:0;transition:opacity 0.35s var(--ease);display:flex;flex-direction:column;justify-content:flex-end;padding:22px 20px;}
.pitem:hover .pitem__overlay{opacity:1;}
.pitem__title{font-size:16px;font-weight:500;color:white;margin-bottom:3px;}
.pitem__cat{font-size:9px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--orange);}
.portfolio-cta{display:flex;justify-content:center;padding-top:8px;}

/* ─── FULL PORTFOLIO PAGE ─── */
.pf-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:44px;}
.pf-filter{font-family:var(--font-sans);font-size:12px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;padding:8px 18px;border:1px solid var(--border-mid);color:var(--text-soft);background:var(--bg-alt);border-radius:2px;cursor:pointer;transition:all 0.2s;}
.pf-filter.active,.pf-filter:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-pale);}
[data-theme="dark"] .pf-filter.active,[data-theme="dark"] .pf-filter:hover{border-color:var(--orange);color:var(--orange);background:rgba(220,103,57,0.1);}
.portfolio-masonry{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:44px;}
.pm-item{position:relative;overflow:hidden;cursor:pointer;display:block;aspect-ratio:16/9;border-radius:0;}
.pm-item img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform 0.8s var(--ease);}
.pm-item:hover img{transform:scale(1.05);}
.pm-item__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(9,69,75,0.85) 0%,transparent 55%);opacity:0;transition:opacity 0.35s var(--ease);display:flex;flex-direction:column;justify-content:flex-end;padding:22px 20px;}
.pm-item:hover .pm-item__overlay{opacity:1;}
.pm-item__title{font-size:16px;font-weight:500;color:white;margin-bottom:3px;}
.pm-item__meta{font-size:9px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--orange);}

/* ─── VIDEO SECTION — always dark for cinema feel ─── */
.video-section{background:#15171a;padding:100px 0;}
.video-section__inner{padding:0 60px;}
.video-player{position:relative;width:100%;aspect-ratio:16/9;background:#000;overflow:hidden;border-radius:2px;}
.video-player video{width:100%;height:100%;object-fit:cover;display:block;}
.video-player iframe{width:100%;height:100%;border:none;}
.video-player__poster{position:absolute;inset:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity 0.3s;z-index:3;}
.video-player__poster.hidden{opacity:0;pointer-events:none;}
.video-player__poster img{width:100%;height:100%;object-fit:cover;opacity:0.5;}
.video-player__play{position:absolute;width:72px;height:72px;border-radius:50%;background:rgba(9,69,75,0.9);display:flex;align-items:center;justify-content:center;transition:transform 0.25s,background 0.25s;}
.video-player__poster:hover .video-player__play{transform:scale(1.1);background:var(--teal);}
.play-tri{width:0;height:0;border-style:solid;border-width:12px 0 12px 22px;border-color:transparent transparent transparent white;margin-left:5px;}

/* Custom controls bar */
.vplayer-controls{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:10px 16px 12px;background:linear-gradient(to top,rgba(0,0,0,0.82) 0%,rgba(0,0,0,0.35) 60%,transparent 100%);opacity:0;transform:translateY(6px);transition:opacity 0.25s,transform 0.25s;display:flex;flex-direction:column;gap:8px;}
.video-player:hover .vplayer-controls,.video-player.controls-visible .vplayer-controls{opacity:1;transform:translateY(0);}
.vplayer-progress{position:relative;width:100%;height:4px;border-radius:3px;background:rgba(255,255,255,0.25);cursor:pointer;}
.vplayer-progress__fill{position:absolute;left:0;top:0;height:100%;border-radius:3px;background:var(--orange);width:0%;pointer-events:none;}
.vplayer-progress__buffer{position:absolute;left:0;top:0;height:100%;border-radius:3px;background:rgba(255,255,255,0.18);width:0%;pointer-events:none;}
.vplayer-progress__handle{position:absolute;top:50%;width:12px;height:12px;border-radius:50%;background:var(--orange);transform:translate(-50%,-50%);left:0%;box-shadow:0 0 0 4px rgba(220,103,57,0.2);pointer-events:none;}
.vplayer-row{display:flex;align-items:center;gap:14px;}
.vplayer-btn{background:none;border:none;color:white;cursor:pointer;display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;opacity:0.9;transition:opacity 0.15s;padding:0;}
.vplayer-btn:hover{opacity:1;}
.vplayer-btn svg{width:18px;height:18px;}
.vplayer-time{font-size:11px;color:rgba(255,255,255,0.8);font-family:var(--font-sans);letter-spacing:0.02em;flex-shrink:0;min-width:84px;}
.vplayer-spacer{flex:1;}
.vplayer-vol-wrap{display:flex;align-items:center;gap:6px;}
.vplayer-vol{width:60px;height:3px;-webkit-appearance:none;appearance:none;background:rgba(255,255,255,0.3);border-radius:2px;outline:none;cursor:pointer;}
.vplayer-vol::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:white;cursor:pointer;}
.vplayer-vol::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:white;border:none;cursor:pointer;}

.vtabs{display:flex;gap:4px;margin-top:14px;flex-wrap:wrap;}
.vtab{flex:1;min-width:140px;padding:13px 16px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);cursor:pointer;transition:all 0.2s;border-radius:2px;text-align:left;font-family:var(--font-sans);}
.vtab.active{border-color:var(--orange);background:rgba(220,103,57,0.08);}
.vtab__label{font-size:9px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--orange);}
.vtab__title{font-size:14px;color:white;margin-top:3px;font-weight:400;}

/* ─── 360 TOURS ─── */
.tours-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px;}
.tcard{border:1px solid var(--border);border-radius:2px;overflow:hidden;background:var(--bg-alt);transition:all 0.3s var(--ease);}
.tcard:hover{border-color:var(--teal);transform:translateY(-4px);box-shadow:0 12px 32px rgba(9,69,75,0.1);}
.tcard__thumb{height:200px;position:relative;overflow:hidden;}
.tcard__thumb img{transition:transform 0.5s var(--ease);}
.tcard:hover .tcard__thumb img{transform:scale(1.04);}
.tcard__badge{position:absolute;top:12px;left:12px;background:var(--teal);padding:3px 10px;border-radius:1px;font-size:8px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:white;}
.tcard__body{padding:20px 22px 24px;}
.tcard__title{font-size:17px;font-weight:500;color:var(--text);margin-bottom:4px;}
.tcard__meta{font-size:13px;color:var(--text-soft);margin-bottom:16px;}
.tcard__btn{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--teal);border:1px solid var(--teal);padding:7px 14px;border-radius:2px;transition:all 0.2s;font-family:var(--font-sans);}
.tcard__btn:hover{background:var(--teal);color:white;}
[data-theme="dark"] .tcard__btn{color:var(--orange);border-color:var(--orange);}
[data-theme="dark"] .tcard__btn:hover{background:var(--orange);color:white;}

/* ─── ABOUT STRIP — always teal (intentional fixed-color band) ─── */
.about-strip{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:560px;}
.about-strip__img{position:relative;overflow:hidden;}
.about-strip__img img{transition:transform 8s ease;}
.about-strip__img:hover img{transform:scale(1.03);}
.about-strip__content{background:var(--teal);padding:72px 64px;display:flex;flex-direction:column;justify-content:center;}
.about-strip__tag{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,0.1);padding:8px 16px;border-radius:2px;margin-bottom:24px;align-self:flex-start;}
.about-strip__tag-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:pulse 2s ease-in-out infinite;}
.about-strip__tag-text{font-size:10px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.75);}
@keyframes pulse{0%,100%{opacity:0.4;transform:scale(0.85);}50%{opacity:1;transform:scale(1.15);}}
.about-strip__title{font-family:var(--font-sans);font-weight:600;font-size:clamp(32px,3.2vw,46px);color:white;line-height:1.18;margin-bottom:16px;}
.about-strip__title em{font-style:normal;color:var(--orange);}
.about-strip__body{font-size:16px;font-weight:300;color:rgba(255,255,255,0.75);line-height:1.85;}
.about-strip__list{margin-top:28px;display:flex;flex-direction:column;gap:12px;}
.about-strip__item{display:flex;align-items:flex-start;gap:12px;font-size:15px;font-weight:300;color:rgba(255,255,255,0.75);line-height:1.75;}
.about-strip__dot{width:5px;height:5px;border-radius:50%;background:var(--orange);flex-shrink:0;margin-top:8px;}

/* ─── PROCESS ─── */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;margin-top:48px;}
.process-steps::before{content:'';position:absolute;top:26px;left:12%;right:12%;height:1px;background:var(--border-mid);}
.pstep{padding:0 24px;text-align:center;position:relative;z-index:1;}
.pstep__dot{width:52px;height:52px;border-radius:50%;background:var(--bg-alt);border:1px solid var(--border-mid);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:all 0.3s;}
.pstep:hover .pstep__dot{border-color:var(--teal);background:var(--teal-pale);}
[data-theme="dark"] .pstep:hover .pstep__dot{border-color:var(--orange);background:rgba(220,103,57,0.1);}
.pstep__n{font-family:var(--font-sans);font-size:20px;font-weight:700;color:var(--teal);}
[data-theme="dark"] .pstep__n{color:var(--orange);}
.pstep__title{font-size:16px;font-weight:500;color:var(--text);margin-bottom:8px;}
.pstep__desc{font-size:14px;font-weight:300;color:var(--text-soft);line-height:1.85;}

/* ─── TESTIMONIALS ─── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px;}
.testicard{background:var(--bg-alt);border:1px solid var(--border);border-radius:2px;padding:40px 34px;}
.testicard__q{font-family:var(--font-sans);font-size:52px;font-weight:700;color:var(--teal);line-height:0.5;margin-bottom:16px;}
[data-theme="dark"] .testicard__q{color:var(--orange);}
.testicard__text{font-size:15px;font-weight:300;color:var(--text-mid);line-height:1.9;margin-bottom:22px;}
.testicard__author{display:flex;align-items:center;gap:10px;}
.testicard__av{width:38px;height:38px;border-radius:50%;background:var(--teal-pale);border:1px solid rgba(9,69,75,0.2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--teal);flex-shrink:0;}
.testicard__name{font-size:15px;font-weight:500;color:var(--text);}
.testicard__role{font-size:10px;color:var(--text-soft);margin-top:1px;}

/* ─── CTA BAND — always teal ─── */
.cta-band{background:var(--teal);padding:80px 60px;display:flex;align-items:center;justify-content:space-between;gap:40px;}
.cta-band__title{font-family:var(--font-sans);font-size:clamp(28px,2.8vw,42px);font-weight:600;color:white;line-height:1.22;}
.cta-band__sub{font-size:15px;font-weight:300;color:rgba(255,255,255,0.62);margin-top:8px;}
.cta-band__actions{display:flex;gap:14px;flex-shrink:0;}

/* ─── CONTACT PAGE ─── */
.contact-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;padding-top:20px;}
.contact-info{display:flex;flex-direction:column;gap:0;}
.ci-item{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--border);}
.ci-item:first-child{padding-top:0;}
.ci-icon{width:40px;height:40px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--teal);}
[data-theme="dark"] .ci-icon{color:var(--orange);}
.ci-label{font-size:9px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-soft);margin-bottom:3px;}
.ci-val{font-size:16px;color:var(--text);font-weight:400;}
.contact-form{display:flex;flex-direction:column;gap:14px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fg label{font-size:9px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-soft);}
.fg input,.fg select,.fg textarea{font-family:var(--font-sans);font-size:15px;font-weight:300;color:var(--text);background:var(--bg-alt);border:1px solid var(--border-mid);border-radius:2px;padding:11px 14px;outline:none;transition:border-color 0.2s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--teal);}
.fg select option{background:var(--bg-alt);color:var(--text);}
.fg textarea{resize:none;height:100px;}
.contact-map{width:100%;height:320px;background:var(--teal-pale);border-radius:2px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-top:28px;overflow:hidden;position:relative;}
[data-theme="dark"] .contact-map{background:rgba(9,69,75,0.15);}
.contact-map__label{text-align:center;color:var(--text-soft);}
.contact-map__pin{font-size:32px;margin-bottom:8px;}
.contact-map__text{font-size:15px;font-weight:400;color:var(--teal);}
[data-theme="dark"] .contact-map__text{color:var(--orange);}
.faq-list{margin-top:48px;}
.faq-item{border-bottom:1px solid var(--border);padding:18px 0;}
.faq-item:first-child{border-top:1px solid var(--border);}
.faq-q{font-size:16px;font-weight:500;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;}
.faq-q::after{content:'+';font-size:18px;color:var(--teal);font-weight:300;}
[data-theme="dark"] .faq-q::after{color:var(--orange);}
.faq-a{font-size:15px;font-weight:300;color:var(--text-mid);line-height:1.8;padding-top:10px;display:none;}
.faq-item.open .faq-a{display:block;}
.faq-item.open .faq-q::after{content:'−';}

/* ─── FOOTER — always dark ─── */
.footer{background:var(--footer-bg);padding:60px 60px 36px;}
.footer__main{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,0.07);margin-bottom:28px;}
.footer__brand{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.footer__brand-icon{width:34px;height:34px;object-fit:contain;}
.footer__brand-name{font-size:19px;font-weight:600;color:white;letter-spacing:0.01em;line-height:1;}
.footer__brand-name span{color:var(--orange);}
.footer__brand-sub{font-size:8px;letter-spacing:0.26em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:2px;}
.footer__brand-desc{font-size:14px;font-weight:300;color:var(--footer-text);line-height:1.9;}
.footer__col h4{font-size:9px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;color:var(--sand);margin-bottom:16px;}
.footer__col ul{display:flex;flex-direction:column;gap:9px;}
.footer__col a{font-size:14px;font-weight:300;color:var(--footer-text);transition:color 0.2s;}
.footer__col a:hover{color:white;}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;}
.footer__copy{font-size:10px;color:rgba(255,255,255,0.3);letter-spacing:0.03em;}
.footer__copy span{color:var(--orange);}
.footer__social{display:flex;gap:10px;}
.footer__social a{width:30px;height:30px;border:1px solid rgba(255,255,255,0.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.4);font-size:11px;font-weight:500;transition:all 0.2s;}
.footer__social a:hover{border-color:var(--orange);color:var(--orange);}

/* ─── LIGHTBOX ─── */
.lightbox{position:fixed;inset:0;background:rgba(10,12,14,0.97);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s;}
.lightbox.open{opacity:1;pointer-events:all;}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;width:auto;height:auto;border-radius:2px;}
.lightbox__close{position:absolute;top:20px;right:28px;font-size:28px;color:rgba(255,255,255,0.5);cursor:pointer;background:none;border:none;line-height:1;transition:color 0.2s;font-family:sans-serif;}
.lightbox__close:hover{color:white;}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:white;cursor:pointer;transition:background 0.2s;font-size:18px;}
.lightbox__nav:hover{background:rgba(255,255,255,0.15);}
.lightbox__prev{left:20px;}
.lightbox__next{right:20px;}

/* ─── FADE IN ─── */
.fade-in{opacity:0;transform:translateY(16px);transition:opacity 0.65s ease,transform 0.65s ease;}
.fade-in.visible{opacity:1;transform:none;}

/* ════════════════════════════════════════════
   ADMIN PANEL
════════════════════════════════════════════ */
.admin-body{background:#14161a;color:#e8e6e0;min-height:100vh;font-family:var(--font-sans);}
.admin-shell{display:flex;min-height:100vh;}
.admin-side{width:240px;flex-shrink:0;background:#0e1013;border-right:1px solid #24272c;padding:28px 20px;display:flex;flex-direction:column;}
.admin-logo{display:flex;align-items:center;gap:10px;margin-bottom:40px;padding:0 4px;}
.admin-logo img{width:32px;height:32px;}
.admin-logo-text{font-size:15px;font-weight:600;color:white;}
.admin-logo-text span{color:var(--orange);}
.admin-nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:6px;font-size:13px;color:#9a958a;cursor:pointer;transition:all 0.2s;margin-bottom:2px;}
.admin-nav-item:hover{background:#1a1d22;color:#e8e6e0;}
.admin-nav-item.active{background:rgba(220,103,57,0.12);color:var(--orange);}
.admin-nav-item svg{width:16px;height:16px;flex-shrink:0;}
.admin-side-footer{margin-top:auto;padding:14px;background:#1a1d22;border-radius:6px;}
.admin-side-footer p{font-size:11px;color:#7a766c;line-height:1.6;}
.admin-main{flex:1;padding:36px 44px;overflow-y:auto;}
.admin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:36px;}
.admin-title{font-size:24px;font-weight:600;color:white;margin-bottom:6px;}
.admin-sub{font-size:13px;color:#8d877c;}
.admin-panel{display:none;}
.admin-panel.active{display:block;}
.admin-card{background:#1a1d22;border:1px solid #262a30;border-radius:10px;padding:28px;margin-bottom:20px;}
.admin-card h3{font-size:15px;font-weight:500;color:white;margin-bottom:6px;}
.admin-card p.hint{font-size:12px;color:#7a766c;margin-bottom:20px;line-height:1.6;}
.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;}
.admin-tile{position:relative;border-radius:8px;overflow:hidden;border:1px solid #262a30;aspect-ratio:4/3;cursor:pointer;transition:border-color 0.2s;}
.admin-tile:hover{border-color:var(--orange);}
.admin-tile img{width:100%;height:100%;object-fit:cover;}
.admin-tile__check{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,0.5);border:1.5px solid rgba(255,255,255,0.5);display:flex;align-items:center;justify-content:center;font-size:12px;color:transparent;transition:all 0.2s;}
.admin-tile.selected .admin-tile__check{background:var(--orange);border-color:var(--orange);color:white;}
.admin-tile.selected{border-color:var(--orange);}
.admin-tile__label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,0.8),transparent);padding:8px;font-size:10px;color:white;}
.admin-upload-zone{border:2px dashed #2e323a;border-radius:8px;padding:40px 20px;text-align:center;cursor:pointer;transition:all 0.2s;}
.admin-upload-zone:hover{border-color:var(--orange);background:rgba(220,103,57,0.04);}
.admin-upload-zone svg{width:32px;height:32px;color:#5a564c;margin-bottom:12px;}
.admin-upload-zone p{font-size:13px;color:#9a958a;margin-bottom:4px;}
.admin-upload-zone span{font-size:11px;color:#5a564c;}
.admin-input{width:100%;background:#14161a;border:1px solid #2e323a;border-radius:6px;padding:10px 14px;font-size:13px;color:#e8e6e0;font-family:var(--font-sans);outline:none;transition:border-color 0.2s;}
.admin-input:focus{border-color:var(--orange);}
.admin-label{font-size:11px;font-weight:500;color:#9a958a;letter-spacing:0.04em;margin-bottom:6px;display:block;}
.admin-fg{margin-bottom:16px;}
.admin-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.admin-toast{position:fixed;bottom:24px;right:24px;background:#1a1d22;border:1px solid var(--orange);border-radius:8px;padding:14px 20px;display:flex;align-items:center;gap:10px;font-size:13px;color:white;transform:translateY(120px);opacity:0;transition:all 0.35s var(--ease);z-index:500;}
.admin-toast.show{transform:translateY(0);opacity:1;}
.admin-toast__icon{color:#5cba7d;}
.admin-list{display:flex;flex-direction:column;gap:1px;background:#262a30;border-radius:8px;overflow:hidden;}
.admin-list-row{background:#1a1d22;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.admin-list-row__info{display:flex;align-items:center;gap:12px;flex:1;}
.admin-list-row__thumb{width:48px;height:36px;border-radius:4px;overflow:hidden;flex-shrink:0;background:#262a30;}
.admin-list-row__name{font-size:13px;color:white;}
.admin-list-row__meta{font-size:11px;color:#7a766c;margin-top:2px;}
.admin-badge{font-size:9px;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;padding:3px 9px;border-radius:10px;background:rgba(92,186,125,0.15);color:#5cba7d;}
.admin-badge--orange{background:rgba(220,103,57,0.15);color:var(--orange);}
.admin-section-title{font-size:13px;font-weight:500;color:#c7c2b8;margin:28px 0 14px;text-transform:uppercase;letter-spacing:0.08em;}
.admin-section-title:first-child{margin-top:0;}
.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid #262a30;}
.admin-tab{padding:10px 18px;font-size:12px;color:#8d877c;cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s;}
.admin-tab.active{color:white;border-bottom-color:var(--orange);}
.admin-login{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0e1013;}
.admin-login-box{background:#1a1d22;border:1px solid #262a30;border-radius:12px;padding:48px 40px;width:380px;}
.admin-login-box img{width:48px;margin:0 auto 20px;display:block;}
.admin-login-box h2{font-size:18px;color:white;text-align:center;margin-bottom:6px;}
.admin-login-box p{font-size:12px;color:#7a766c;text-align:center;margin-bottom:28px;}

/* ─── MAP & EMBED RESPONSIVENESS ─── */
.contact-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.embed-frame {
  position: relative;
  background: #0e1013;
}
.embed-frame iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.embed-fallback {
  position: absolute;
  bottom: 12px;
  right: 12px;
  background: rgba(24, 26, 29, 0.85);
  padding: 6px 12px;
  border-radius: 2px;
  font-size: 11px;
  letter-spacing: 0.05em;
  border: 1px solid rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(4px);
  z-index: 10;
  transition: background 0.2s, border-color 0.2s;
}
.embed-fallback a {
  color: white !important;
  font-weight: 500;
  text-decoration: none !important;
  text-transform: uppercase;
}
.embed-fallback:hover {
  background: var(--orange);
  border-color: var(--orange);
}

.service-video-preview {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Focus outline for keyboard navigation */
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--orange);
  outline-offset: 4px;
}

/* Animated Hamburger to X */
.nav--menu-open .nav__hamburger span:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.nav--menu-open .nav__hamburger span:nth-child(2) {
  opacity: 0;
}
.nav--menu-open .nav__hamburger span:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}

body.nav--menu-open {
  overflow: hidden !important;
}

/* Touch Target Expansions using Pseudo-elements */
.theme-toggle::after {
  content: '';
  position: absolute;
  top: -7px;
  bottom: -7px;
  left: -5px;
  right: -5px;
}
.vplayer-btn {
  position: relative;
}
.vplayer-btn::after {
  content: '';
  position: absolute;
  top: -8px;
  bottom: -8px;
  left: -8px;
  right: -8px;
}
.btn--sm {
  position: relative;
}
.btn--sm::after {
  content: '';
  position: absolute;
  top: -8px;
  bottom: -8px;
  left: 0;
  right: 0;
}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .nav{padding:0 32px;}
  .section{padding:72px 40px;}
  .hero__content{padding:0 40px;}
  .hero__scroll{right:40px;}
  .statsbar{padding:0 40px;grid-template-columns:repeat(2,1fr);}
  .stat:nth-child(2){border-right:none;}
  .stat:nth-child(3){border-top:1px solid var(--border);}
  .stat:nth-child(4){border-top:1px solid var(--border);border-right:none;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .portfolio-masonry{grid-template-columns:repeat(2,1fr);gap:6px;}
  .about-strip{grid-template-columns:1fr;}
  .about-strip__content{padding:52px 40px;}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:32px;}
  .process-steps::before{display:none;}
  .testi-grid{grid-template-columns:1fr 1fr;}
  .cta-band{flex-direction:column;text-align:center;padding:60px 40px;}
  .cta-band__actions{justify-content:center;}
  .contact-layout{grid-template-columns:1fr;}
  .footer__main{grid-template-columns:1fr 1fr;gap:32px;}
  .tours-grid{grid-template-columns:1fr 1fr;}
  .video-section__inner{padding:0 40px;}
  .page-hero{padding:120px 40px 64px;}
  .portfolio-page-hero{padding:120px 40px 64px;}
  .svc-detail{grid-template-columns:1fr;}
  .svc-detail--reverse .svc-detail__img{order:0;}
  .svc-detail--reverse .svc-detail__content{order:0;}
  .portfolio-grid-home{grid-template-columns:repeat(6,1fr);grid-auto-rows:220px;}
  .pitem:nth-child(1){grid-column:span 6;grid-row:span 1;}
  .pitem:nth-child(2){grid-column:span 6;grid-row:span 1;}
  .pitem:nth-child(n){grid-column:span 3;grid-row:span 1;}
  .admin-side{width:200px;}
  .admin-main{padding:28px;}
  .footer { padding: 48px 40px 28px; }
}
@media(max-width:768px){
  .nav{padding:0 20px;}
  .nav__links{
    display: none;
    position: fixed;
    top: 76px;
    left: 0;
    width: 100%;
    height: calc(100vh - 76px);
    background: #181a1d;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 40px 24px;
    gap: 24px;
    z-index: 199;
    overflow-y: auto;
    border-top: 1px solid rgba(255,255,255,0.06);
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.25s var(--ease), transform 0.25s var(--ease);
  }
  .nav__links.nav__links--open{
    display: flex;
    opacity: 1;
    transform: translateY(0);
  }
  .nav__links li {
    width: 100%;
    text-align: center;
  }
  .nav__link {
    display: block;
    padding: 12px 20px;
    font-size: 16px;
    text-align: center;
  }
  .nav__link::after {
    display: none;
  }
  .nav__cta {
    display: block;
    margin: 8px auto 0;
    max-width: 220px;
    text-align: center;
    padding: 12px 24px;
    font-size: 13px;
  }
  .nav__hamburger{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 12px;
    cursor: pointer;
    background: none;
    border: none;
    z-index: 201;
    margin-right: -8px;
  }
  .nav__right{
    display: flex;
    align-items: center;
    gap: 16px;
    margin-left: auto;
    margin-right: 12px;
  }
  .section{padding:56px 20px;}
  .hero__content{padding:0 20px;}
  .hero__scroll{display:none;}
  .statsbar{padding:0 20px;grid-template-columns:1fr 1fr;}
  .services-grid{grid-template-columns:1fr;}
  .portfolio-masonry{grid-template-columns:1fr;gap:6px;}
  .portfolio-grid-home{grid-auto-rows:200px;}
  .pitem:nth-child(n){grid-column:span 6;grid-row:span 1;}
  .frow{grid-template-columns:1fr;}
  .footer__main{grid-template-columns:1fr;gap:24px;}
  .cta-band{padding:52px 20px;}
  .tours-grid{grid-template-columns:1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .process-steps{grid-template-columns:1fr;}
  .vtabs{flex-direction:column;}
  .video-section__inner{padding:0 20px;}
  .page-hero{padding:110px 20px 56px;}
  .portfolio-page-hero{padding:110px 20px 56px;}
  .contact-layout{gap:40px;}
  .pf-filters{gap:4px;}
  .pf-filter{padding:10px 16px;}
  .admin-shell{flex-direction:column;}
  .admin-side{width:100%;flex-direction:row;align-items:center;padding:14px 20px;overflow-x:auto;}
  .admin-logo{margin-bottom:0;margin-right:20px;flex-shrink:0;}
  .admin-nav-item{margin-bottom:0;margin-right:8px;flex-shrink:0;white-space:nowrap;}
  .admin-side-footer{display:none;}
  .admin-row-2{grid-template-columns:1fr;}
  .admin-list-row{flex-direction:column;align-items:stretch;gap:12px;padding:14px;}
  .admin-list-row > div:last-child{display:flex;justify-content:flex-end;gap:8px;width:100%;}
  .tcard__btn{padding:10px 18px;}
  .svc-detail__img{height:300px;}

  /* Mobile text: keep readable but don't overflow */
  body{font-size:15px;}
  .section__body{font-size:15px;}
  .svc__desc{font-size:14px;}
  .about-strip__body{font-size:15px;}
  .hero__sub{font-size:15px;}
  .stat__n{font-size:36px;}
  .testicard__text{font-size:14px;}
  .hero__actions { flex-direction: column; width: 100%; gap: 12px; }
  .hero__actions .btn { width: 100%; }
  .cta-band__actions { flex-direction: column; width: 100%; gap: 12px; }
  .cta-band__actions .btn { width: 100%; }
  .about-strip__content { padding: 48px 20px; }
  .footer { padding: 40px 20px 24px; }
}

@media(max-width:480px){
  .admin-main{padding:16px;}
  .admin-card{padding:16px;}
  .admin-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;}
  .vplayer-vol-wrap{display:none;}
  .svc-detail__img{height:220px;}
}
@media(max-width:375px){
  .nav__name{font-size:18px;}
  .nav__icon{width:36px;height:36px;}
  .nav__right{gap:8px;margin-right:4px;}
  .theme-toggle{width:54px;}
}

/* ════════════════════════════════════════════
   ADMIN CMS v3 — NEW UI ELEMENTS
   Appended below existing styles.
   No existing selectors changed.
════════════════════════════════════════════ */

/* ─── Source Type Selector ─── */
.admin-source-type-group{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:4px;}
.admin-source-type-option{display:flex;align-items:center;gap:6px;cursor:pointer;padding:7px 14px;border:1px solid #2e323a;border-radius:6px;font-size:12px;color:#9a958a;transition:all 0.2s;user-select:none;}
.admin-source-type-option:hover{border-color:var(--orange);color:#e8e6e0;}
.admin-source-type-option input[type="radio"]{display:none;}
.admin-source-type-option:has(input:checked){border-color:var(--orange);background:rgba(220,103,57,0.1);color:var(--orange);}

/* ─── Storage Bar ─── */
.admin-storage-bar{height:6px;background:#1e2126;border-radius:3px;overflow:hidden;margin-top:12px;}
.admin-storage-bar__fill{height:100%;border-radius:3px;background:#5cba7d;transition:width 0.4s ease,background 0.3s;}

/* ─── Button variants ─── */
.admin-body .btn--sm{padding:6px 12px;font-size:11px;}
.admin-body .btn--ghost{background:transparent;border:1px solid #2e323a;color:#9a958a;padding:8px 16px;border-radius:6px;font-size:12px;cursor:pointer;transition:all 0.2s;text-decoration:none;display:inline-block;}
.admin-body .btn--ghost:hover{border-color:var(--orange);color:var(--orange);}
.admin-body .btn--danger{background:rgba(179,64,47,0.15);border:1px solid #b3402f;color:#e07060;padding:8px 16px;border-radius:6px;font-size:12px;cursor:pointer;transition:all 0.2s;}
.admin-body .btn--danger:hover{background:rgba(179,64,47,0.25);}
.admin-body .btn--orange{background:var(--orange);color:white;padding:11px 24px;border-radius:6px;font-size:13px;border:none;cursor:pointer;font-family:var(--font-sans);font-weight:500;transition:opacity 0.2s;margin-top:4px;}
.admin-body .btn--orange:hover{opacity:0.88;}
.admin-body .btn--orange:disabled{opacity:0.45;cursor:not-allowed;}

/* ─── Green badge for Published status ─── */
.admin-badge--green{background:rgba(92,186,125,0.15);color:#5cba7d;}

/* ─── Upload zone active state ─── */
.admin-upload-zone.drag-over{border-color:var(--orange);background:rgba(220,103,57,0.06);}

/* ─── Responsive admin source-type group ─── */
@media(max-width:640px){
  .admin-source-type-group{flex-direction:column;}
}
