/* ============================================================
   EKTA CHOTO AGENCY — global stylesheet
   Brand: black + vivid green (#1BF45A)
   Fonts: Domine (display) / Nunito Sans (body)
   ============================================================ */

:root{
  --bg:        #0A0A0A;
  --bg-2:      #111111;
  --surface:   #151515;
  --surface-2: #1C1C1C;
  --line:      rgba(255,255,255,.10);
  --line-2:    rgba(255,255,255,.18);
  --green:     #1BF45A;
  --green-dim: #14c049;
  --green-ink: #1BF45A;
  --nav-bg:    rgba(10,10,10,.72);
  --ink:       #F4F4F2;
  --muted:     #9A9A95;
  --muted-2:   #6E6E69;

  --maxw: 1200px;
  --pad: clamp(20px, 5vw, 64px);
  --radius: 18px;

  --font-display: "Domine", Georgia, serif;
  --font-body: "Nunito Sans", system-ui, sans-serif;
}

/* ---------- LIGHT THEME ---------- */
html[data-theme="light"]{
  --bg:        #FBFBF9;
  --bg-2:      #F1F1EC;
  --surface:   #FFFFFF;
  --surface-2: #F5F5F0;
  --line:      rgba(0,0,0,.10);
  --line-2:    rgba(0,0,0,.16);
  --green:     #1BF45A;       /* neon kept for fills (buttons, marquee, badges) */
  --green-ink: #0A8F36;       /* deeper green for readable text on white */
  --ink:       #121210;
  --muted:     #57574E;
  --muted-2:   #8B8B81;
  --nav-bg:    rgba(255,255,255,.82);
}
html[data-theme="light"] body::after{ mix-blend-mode:multiply; opacity:.035; }

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
  position:relative;
}

/* subtle film grain over everything */
body::after{
  content:"";
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
ul{ list-style:none; }

h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.1;
  letter-spacing:-.012em;
}

.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
.section{ padding:clamp(64px,10vw,140px) 0; }

.eyebrow{
  font-family:var(--font-display);
  font-size:13px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--green-ink);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--green); display:inline-block; }

.lead{ color:var(--muted); font-size:clamp(17px,2vw,20px); max-width:60ch; }

/* ---------- buttons ---------- */
.btn{
  --b:var(--green);
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700; font-size:15px; letter-spacing:.01em;
  padding:15px 26px; border-radius:999px; cursor:pointer; border:1px solid transparent;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), background .25s, color .25s, border-color .25s;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--green); color:#04210d; }
.btn-primary:hover{ background:#3bff75; }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--green-ink); color:var(--green-ink); }
.btn .arr{ transition:transform .25s; }
.btn:hover .arr{ transform:translate(3px,-3px); }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:1000;
  backdrop-filter:saturate(140%) blur(12px);
  background:var(--nav-bg);
  border-bottom:1px solid var(--line);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:72px; }
.brand{ font-family:var(--font-display); font-weight:700; font-size:19px; letter-spacing:-.01em; display:flex; align-items:center; gap:9px; }
.brand .dot{ width:11px; height:11px; border-radius:50%; background:var(--green); box-shadow:0 0 14px var(--green); }
.brand b{ color:var(--green-ink); }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-size:15px; color:var(--muted); font-weight:500; transition:color .2s; position:relative; }
.nav-links a:hover, .nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{ content:""; position:absolute; left:0; bottom:-6px; width:100%; height:2px; background:var(--green); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.burger span{ width:24px; height:2px; background:var(--ink); transition:.3s; }

@media(max-width:900px){
  .nav-links{
    position:fixed; inset:72px 0 auto 0; flex-direction:column; gap:0;
    background:var(--bg-2); border-bottom:1px solid var(--line);
    padding:10px var(--pad) 24px; transform:translateY(-120%); transition:transform .35s ease; align-items:flex-start;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ width:100%; padding:14px 0; font-size:18px; border-bottom:1px solid var(--line); }
  .nav-links a.active::after{ display:none; }
  .burger{ display:flex; }
  .nav-cta .btn{ display:none; }
}

/* ---------- hero ---------- */
.hero{ position:relative; padding:clamp(70px,11vw,150px) 0 clamp(50px,7vw,90px); overflow:hidden; }
.hero::before{
  content:""; position:absolute; top:-30%; right:-10%; width:60vw; height:60vw; max-width:760px; max-height:760px;
  background:radial-gradient(circle, rgba(27,244,90,.16), transparent 62%); pointer-events:none; filter:blur(8px);
}
.hero h1{ font-size:clamp(44px,8.5vw,108px); line-height:1.0; }
.hero h1 .hl{ color:var(--green-ink); }
.hero .stroke{ -webkit-text-stroke:1.4px var(--green-ink); color:transparent; }
.hero-sub{ margin-top:26px; max-width:48ch; }
.hero-actions{ margin-top:38px; display:flex; gap:14px; flex-wrap:wrap; }
.hero-meta{ margin-top:54px; display:flex; flex-wrap:wrap; gap:38px; border-top:1px solid var(--line); padding-top:26px; }
.hero-meta div span{ display:block; font-family:var(--font-display); font-weight:700; font-size:30px; color:var(--green-ink); }
.hero-meta div small{ color:var(--muted); font-size:13px; letter-spacing:.04em; }

/* ---------- marquee ---------- */
.marquee{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--green); overflow:hidden; }
.marquee-track{ display:flex; gap:0; white-space:nowrap; animation:scroll 26s linear infinite; }
.marquee span{ font-family:var(--font-display); font-weight:700; font-size:clamp(22px,3vw,34px); color:#04210d; padding:14px 28px; letter-spacing:-.01em; text-transform:uppercase; }
.marquee span i{ font-style:normal; opacity:.45; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ---------- section heads ---------- */
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:54px; }
.sec-head h2{ font-size:clamp(32px,5vw,60px); max-width:16ch; }
.sec-head p{ color:var(--muted); max-width:40ch; }

/* ---------- video ---------- */
.video-wrap{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); background:var(--surface); }
.video-wrap::after{ content:""; position:absolute; inset:0; border-radius:var(--radius); box-shadow:inset 0 0 0 1px rgba(27,244,90,.15); pointer-events:none; }
.video-frame{ position:relative; aspect-ratio:16/9; }
.video-frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ---------- services grid ---------- */
.grid{ display:grid; gap:18px; }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
@media(max-width:900px){ .grid-3{ grid-template-columns:1fr 1fr; } }
@media(max-width:620px){ .grid-3,.grid-2{ grid-template-columns:1fr; } }

.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; transition:transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s, background .3s;
}
.card:hover{ transform:translateY(-5px); border-color:var(--green-ink); background:var(--surface-2); }
.card .num{ font-family:var(--font-display); font-weight:700; color:var(--green-ink); font-size:14px; letter-spacing:.1em; }
.card h3{ font-size:21px; margin:14px 0 10px; }
.card p{ color:var(--muted); font-size:15.5px; }

/* ---------- package / pricing cards ---------- */
.pkg-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media(max-width:1000px){ .pkg-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .pkg-grid{ grid-template-columns:1fr; } }

.pkg{
  position:relative; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:30px 26px; display:flex; flex-direction:column;
  transition:transform .3s, border-color .3s;
}
.pkg:hover{ transform:translateY(-6px); border-color:var(--line-2); }
.pkg.feat{ background:linear-gradient(180deg, rgba(27,244,90,.10), var(--surface) 40%); border-color:rgba(27,244,90,.45); }
.pkg .tag{ position:absolute; top:-12px; left:26px; background:var(--green); color:#04210d; font-family:var(--font-display); font-weight:700; font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:6px 12px; border-radius:999px; }
.pkg .pkg-name{ font-family:var(--font-display); font-weight:700; font-size:15px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); }
.pkg .price{ font-family:var(--font-display); font-weight:700; font-size:42px; margin:10px 0 2px; }
.pkg .price small{ font-size:15px; color:var(--muted); font-weight:600; }
.pkg .price .cur{ color:var(--green-ink); }
.pkg .desc{ color:var(--muted); font-size:14.5px; margin:6px 0 18px; min-height:42px; }
.pkg ul.feats{ display:flex; flex-direction:column; gap:11px; margin:0 0 24px; }
.pkg ul.feats li{ font-size:14.5px; color:var(--ink); display:flex; gap:10px; align-items:flex-start; }
.pkg ul.feats li::before{ content:"→"; color:var(--green-ink); font-weight:700; }
.pkg .btn{ margin-top:auto; justify-content:center; width:100%; }

/* ---------- portfolio grid ---------- */
.pf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media(max-width:900px){ .pf-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .pf-grid{ grid-template-columns:1fr; } }

.pf-card{
  position:relative; border-radius:var(--radius); overflow:hidden; cursor:pointer;
  background:var(--surface); border:1px solid var(--line); aspect-ratio:4/3;
  transition:transform .3s, border-color .3s;
}
.pf-card:hover{ transform:translateY(-5px); border-color:var(--green-ink); }
.pf-card .cover{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.92; transition:transform .5s, opacity .3s;
  -webkit-user-drag:none; user-select:none; pointer-events:none; }
.pf-card:hover .cover{ transform:scale(1.05); opacity:1; }
.pf-card .pf-meta{ position:absolute; inset:auto 0 0 0; padding:20px; background:linear-gradient(0deg, rgba(0,0,0,.85), transparent); }
.pf-card .pf-cat{ font-family:var(--font-display); font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--green); }
.pf-card h3{ font-size:20px; margin-top:4px; }
.pf-card .view{ position:absolute; top:16px; right:16px; background:rgba(10,10,10,.7); border:1px solid var(--line-2); border-radius:999px; padding:7px 13px; font-size:12px; font-family:var(--font-display); font-weight:700; }
.pf-empty{ grid-column:1/-1; text-align:center; border:1px dashed var(--line-2); border-radius:var(--radius); padding:60px 24px; color:var(--muted); }

/* placeholder cover when no thumbnail */
.cover-fallback{ position:absolute; inset:0; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--surface-2),var(--surface)); }
.cover-fallback span{ font-family:var(--font-display); font-weight:700; font-size:40px; color:var(--green-ink); opacity:.28; }

/* ---------- protected viewer / lightbox ---------- */
.viewer{ position:fixed; inset:0; z-index:5000; background:rgba(6,6,6,.94); backdrop-filter:blur(6px);
  display:none; flex-direction:column; }
.viewer.open{ display:flex; }
.viewer-bar{ display:flex; align-items:center; justify-content:space-between; padding:16px var(--pad); border-bottom:1px solid var(--line); }
.viewer-bar .vt{ font-family:var(--font-display); font-weight:700; }
.viewer-bar .vt small{ display:block; color:var(--green); font-size:12px; letter-spacing:.1em; text-transform:uppercase; }
.viewer-close{ background:none; border:1px solid var(--line-2); color:var(--ink); border-radius:999px; width:42px; height:42px; cursor:pointer; font-size:20px; }
.viewer-close:hover{ border-color:var(--green); color:var(--green); }
.viewer-stage{ flex:1; overflow:auto; padding:24px var(--pad) 40px; display:flex; flex-direction:column; align-items:center; gap:18px;
  -webkit-user-select:none; user-select:none; }
.viewer-stage canvas{ max-width:min(900px,100%); width:100%; height:auto; border-radius:8px;
  box-shadow:0 20px 60px rgba(0,0,0,.6); -webkit-user-drag:none; pointer-events:none; }
.viewer-nav{ display:flex; align-items:center; gap:16px; padding:14px; }
.viewer-nav button{ background:var(--surface); border:1px solid var(--line-2); color:var(--ink); border-radius:999px; padding:9px 18px; cursor:pointer; font-family:var(--font-display); font-weight:700; }
.viewer-nav button:disabled{ opacity:.3; cursor:default; }
.viewer-loading{ color:var(--muted); padding:40px; }
/* invisible shield over the stage to block right-click / drag on media */
.viewer-shield{ position:absolute; inset:56px 0 0 0; z-index:2; }

/* ---------- about ---------- */
.about-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:50px; align-items:center; }
@media(max-width:820px){ .about-grid{ grid-template-columns:1fr; } }
.about-grid h2{ font-size:clamp(30px,5vw,52px); margin-bottom:20px; }
.stat-row{ display:flex; gap:34px; flex-wrap:wrap; margin-top:30px; }
.stat-row span{ font-family:var(--font-display); font-weight:700; font-size:34px; color:var(--green-ink); display:block; }
.stat-row small{ color:var(--muted); font-size:13px; }
.about-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:34px; }
.about-card .q{ font-family:var(--font-display); font-weight:700; font-size:22px; line-height:1.3; }
.about-card .who{ margin-top:20px; color:var(--muted); font-size:14px; }
.about-card .who b{ color:var(--ink); }

/* ---------- contact / calendar ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:40px; }
@media(max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }
.cal-box{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:34px; }
.cal-box iframe{ width:100%; min-height:620px; border:0; border-radius:12px; background:#fff; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:13px; color:var(--muted); margin-bottom:7px; font-weight:600; letter-spacing:.02em; }
.field input, .field textarea{ width:100%; background:var(--bg-2); border:1px solid var(--line-2); border-radius:12px; padding:14px 16px; color:var(--ink); font-family:var(--font-body); font-size:15px; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--green-ink); }
.field textarea{ min-height:130px; resize:vertical; }
.contact-list li{ display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--line); }
.contact-list li .k{ font-family:var(--font-display); font-weight:700; min-width:90px; color:var(--green-ink); font-size:14px; letter-spacing:.04em; text-transform:uppercase; }

/* ---------- generic page header ---------- */
.page-head{ padding:clamp(56px,9vw,110px) 0 clamp(30px,5vw,60px); }
.page-head h1{ font-size:clamp(40px,7vw,84px); }
.page-head p{ margin-top:18px; }

/* ---------- detail page ---------- */
.detail-grid{ display:grid; grid-template-columns:1.4fr .9fr; gap:46px; align-items:start; }
@media(max-width:880px){ .detail-grid{ grid-template-columns:1fr; } }
.detail-grid h2{ font-size:clamp(26px,4vw,40px); margin:34px 0 16px; }
.detail-grid p{ color:var(--muted); margin-bottom:14px; }
.detail-grid ul.bullets li{ padding:12px 0; border-bottom:1px solid var(--line); display:flex; gap:12px; }
.detail-grid ul.bullets li::before{ content:"✦"; color:var(--green-ink); }
.buy-box{ position:sticky; top:96px; background:var(--surface); border:1px solid rgba(27,244,90,.35); border-radius:var(--radius); padding:30px; }
.buy-box .price{ font-family:var(--font-display); font-weight:700; font-size:48px; }
.buy-box .price .cur{ color:var(--green-ink); }
.buy-box .price small{ font-size:15px; color:var(--muted); font-weight:600; display:block; margin-top:4px; }
.buy-box .btn{ width:100%; justify-content:center; margin-top:22px; }
.buy-box .incl{ margin-top:22px; padding-top:20px; border-top:1px solid var(--line); }
.buy-box .incl li{ font-size:14px; padding:7px 0; display:flex; gap:10px; }
.buy-box .incl li::before{ content:"✓"; color:var(--green-ink); font-weight:700; }

/* ---------- CTA band ---------- */
.cta-band{ background:linear-gradient(120deg,var(--surface),var(--surface-2)); border:1px solid var(--line); border-radius:calc(var(--radius) + 6px); padding:clamp(40px,7vw,80px); text-align:center; position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 120%, rgba(27,244,90,.22), transparent 60%); }
.cta-band > *{ position:relative; }
.cta-band h2{ font-size:clamp(32px,6vw,68px); }
.cta-band p{ color:var(--muted); margin:18px auto 32px; max-width:46ch; }

/* ---------- footer ---------- */
.footer{ border-top:1px solid var(--line); padding:70px 0 36px; margin-top:30px; }
.footer-top{ display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; }
@media(max-width:760px){ .footer-top{ grid-template-columns:1fr; gap:30px; } }
.footer .brand{ font-size:24px; }
.footer .f-tag{ color:var(--muted); margin-top:14px; max-width:34ch; }
.footer h5{ font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); margin-bottom:16px; }
.footer-col a{ display:block; color:var(--muted); padding:6px 0; transition:color .2s; }
.footer-col a:hover{ color:var(--green-ink); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; margin-top:50px; padding-top:24px; border-top:1px solid var(--line); color:var(--muted-2); font-size:13px; }
.footer-bottom .socials{ display:flex; gap:18px; }
.footer-bottom .socials a:hover{ color:var(--green-ink); }

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .marquee-track{ animation:none; }
}

/* ---------- theme toggle ---------- */
.theme-toggle{ display:grid; place-items:center; width:42px; height:42px; border-radius:999px;
  border:1px solid var(--line-2); background:transparent; color:var(--ink); cursor:pointer;
  transition:border-color .2s, color .2s, transform .2s; }
.theme-toggle:hover{ border-color:var(--green); color:var(--green-ink); transform:translateY(-1px); }
.theme-toggle svg{ display:block; }
.theme-toggle .ti-sun{ display:none; }
html[data-theme="light"] .theme-toggle .ti-moon{ display:none; }
html[data-theme="light"] .theme-toggle .ti-sun{ display:block; }
