/* Vikay Design Server — handcrafted stylesheet */
:root{
  --bg:#faf6ef;
  --bg-warm:#f3ece0;
  --paper:#ffffff;
  --ink:#1a1a1a;
  --ink-soft:#3b3a37;
  --muted:#6f6b63;
  --line:#e6dfd2;
  --brand:#c4654a;
  --brand-deep:#a84e35;
  --sage:#5d6f54;
  --gold:#b58a3c;
  --radius:14px;
  --shadow:0 30px 60px -30px rgba(60,30,15,.25);
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;overflow-x:hidden;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand-deep);text-decoration:none;transition:color .2s}
a:hover{color:var(--ink)}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:'Instrument Serif',Georgia,serif;font-weight:400;letter-spacing:-.01em;color:var(--ink);line-height:1.1;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,6vw,4.6rem);overflow-wrap:break-word;hyphens:auto}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:1.5rem}
h4{font-family:'Inter',sans-serif;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);font-weight:600}
p{margin:0 0 1em}
em{font-style:italic;color:var(--brand-deep)}
.muted{color:var(--muted)}
.small{font-size:.875rem}
.eyebrow{display:inline-block;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-deep);font-weight:600;margin-bottom:18px;padding:6px 14px;border:1px solid var(--line);border-radius:999px;background:var(--paper)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,246,239,.85);backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.site-header.scrolled{border-bottom-color:var(--line);background:rgba(250,246,239,.95)}
.nav-wrap{display:flex;align-items:center;gap:32px;padding:18px 24px}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink);font-weight:500}
.brand-mark{border-radius:8px}
.brand-text{font-family:'Instrument Serif',serif;font-size:1.35rem;letter-spacing:-.01em}
.brand-text strong{font-weight:400;color:var(--brand-deep)}
.nav-main{display:flex;gap:28px;margin-left:auto}
.nav-main a{color:var(--ink-soft);font-weight:500;font-size:.95rem;position:relative;padding:6px 0}
.nav-main a::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--brand);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.7,0,.3,1)}
.nav-main a:hover::after,.nav-main a.active::after{transform:scaleX(1);transform-origin:left}
.nav-main a.active{color:var(--ink)}
.nav-cta{margin-left:6px}
.nav-toggle{display:none;background:none;border:0;width:40px;height:40px;cursor:pointer;flex-direction:column;gap:5px;justify-content:center;align-items:center;margin-left:auto}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);transition:transform .3s,opacity .3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:999px;font-weight:500;font-size:.95rem;border:1px solid transparent;cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s,color .25s;font-family:inherit}
.btn-primary{background:var(--ink);color:#faf6ef}
.btn-primary:hover{background:var(--brand-deep);color:#fff;transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(168,78,53,.45)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-2px)}
.btn-link{color:var(--ink);font-weight:500;border-bottom:1px solid var(--ink);padding-bottom:2px;display:inline-block}
.btn-link:hover{color:var(--brand-deep);border-color:var(--brand-deep)}

/* Hero */
.hero{padding:60px 0 80px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.hero-meta{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.85rem;letter-spacing:.04em;margin-bottom:18px}
.hero-meta::before{content:'';width:24px;height:1px;background:var(--brand)}
.hero h1{margin-bottom:24px}
.hero-lede{font-size:1.15rem;color:var(--ink-soft);max-width:540px;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
.hero-proof{display:flex;flex-wrap:wrap;gap:18px;align-items:center;color:var(--muted);font-size:.85rem}
.hero-proof .stars{color:var(--gold);letter-spacing:2px}
.hero-img-wrap{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.hero-img-wrap img{width:100%;height:auto;display:block;aspect-ratio:3/2;object-fit:cover}
.hero-img-badge{position:absolute;left:24px;bottom:24px;background:rgba(255,255,255,.95);padding:14px 18px;border-radius:10px;font-size:.8rem;line-height:1.3;box-shadow:0 12px 30px -10px rgba(0,0,0,.3)}
.hero-img-badge strong{display:block;font-family:'Instrument Serif',serif;font-size:1.5rem;color:var(--brand-deep)}

/* Marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-warm);overflow:hidden;padding:20px 0;font-family:'Instrument Serif',serif;font-size:1.4rem;color:var(--ink-soft)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 40s linear infinite;width:max-content}
.marquee span::before{content:'◆';color:var(--brand);margin-right:60px;font-size:.7em;vertical-align:middle}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Stats */
.stats{padding:90px 0;background:var(--bg)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;border-top:1px solid var(--line);padding-top:50px}
.stat{}
.stat-num{font-family:'Instrument Serif',serif;font-size:clamp(2.4rem,4vw,3.4rem);color:var(--brand-deep);line-height:1}
.stat-label{margin-top:8px;color:var(--muted);font-size:.9rem}

/* Sections */
section{padding:90px 0}
.section-head{max-width:680px;margin:0 0 60px}
.section-head h2{margin-bottom:18px}
.section-head p{font-size:1.05rem;color:var(--ink-soft)}

/* Services grid */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.service-card{background:var(--bg);padding:40px 36px;transition:background .3s}
.service-card:hover{background:var(--paper)}
.service-num{font-family:'Instrument Serif',serif;color:var(--brand);font-size:.95rem;margin-bottom:18px;letter-spacing:.05em}
.service-card h3{margin-bottom:14px}
.service-card ul{list-style:none;padding:0;margin:18px 0 0;border-top:1px dashed var(--line);padding-top:18px}
.service-card li{padding:6px 0;color:var(--ink-soft);font-size:.92rem;display:flex;align-items:center;gap:10px}
.service-card li::before{content:'+';color:var(--brand);font-weight:600}

/* Why */
.why{background:var(--bg-warm)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.why-list{display:grid;grid-template-columns:1fr 1fr;gap:14px 28px;margin-top:28px;padding:0;list-style:none}
.why-list li{padding:14px 0;border-top:1px solid var(--line);color:var(--ink-soft);font-size:.95rem}
.why-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.why-img img{aspect-ratio:4/5;object-fit:cover;width:100%}

/* Portfolio */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.work-card{background:var(--paper);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s}
.work-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.work-thumb{aspect-ratio:4/3;overflow:hidden;background:var(--bg-warm)}
.work-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.work-card:hover .work-thumb img{transform:scale(1.06)}
.work-body{padding:24px 26px 28px}
.work-tag{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.work-body h3{font-size:1.4rem;margin-bottom:8px}
.work-body p{color:var(--ink-soft);font-size:.92rem;margin:0}

/* Testimonials */
.testimonials{background:var(--ink);color:#f3ece0}
.testimonials h2{color:#faf6ef}
.testimonials .muted,.testimonials .section-head p{color:#bdb6a8}
.t-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.t-card{background:#26241f;border:1px solid #36332c;padding:38px 36px;border-radius:var(--radius)}
.t-quote{font-family:'Instrument Serif',serif;font-size:1.35rem;line-height:1.5;color:#faf6ef;margin:0 0 22px;font-style:italic}
.t-meta{display:flex;gap:14px;align-items:center;color:#bdb6a8;font-size:.9rem}
.t-meta strong{color:#fff;display:block;font-family:'Inter',sans-serif;font-weight:600;font-style:normal}

/* CTA */
.cta{padding:120px 0;background:var(--bg-warm);text-align:center}
.cta h2{margin:0 auto 20px;max-width:780px}
.cta p{max-width:560px;margin:0 auto 32px;color:var(--ink-soft);font-size:1.05rem}

/* Footer */
.site-footer{background:var(--bg-warm);border-top:1px solid var(--line);padding:80px 0 24px;color:var(--ink-soft)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:50px;padding-bottom:50px;border-bottom:1px solid var(--line)}
.footer-col h4{margin-bottom:16px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{padding:5px 0;font-size:.92rem}
.footer-col a{color:var(--ink-soft)}
.footer-col a:hover{color:var(--brand-deep)}
.footer-brand .brand-text{font-size:1.25rem}
.footer-brand .muted{margin-top:14px;font-size:.92rem;max-width:340px}
.badge-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.badge{display:inline-block;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;background:var(--paper);border:1px solid var(--line);padding:6px 12px;border-radius:999px;color:var(--ink-soft)}
.footer-col address{font-style:normal;font-size:.92rem;line-height:1.7}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;padding-top:24px;font-size:.85rem;color:var(--muted)}
.footer-bottom p{margin:0}
.legal-links{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:18px}
.legal-links a{color:var(--muted)}
.legal-links a:hover{color:var(--ink)}

/* Cookie banner */
.cookie-banner{position:fixed;left:24px;right:24px;bottom:24px;z-index:90;background:#1a1a1a;color:#faf6ef;border-radius:14px;box-shadow:0 30px 80px -20px rgba(0,0,0,.4);transform:translateY(120%);transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.cookie-banner.show{transform:translateY(0)}
.cookie-inner{display:flex;align-items:center;gap:24px;padding:22px 28px;flex-wrap:wrap}
.cookie-text{flex:1;min-width:260px;font-size:.92rem;color:#d8d1c1}
.cookie-text strong{color:#fff;display:block;margin-bottom:4px;font-family:'Instrument Serif',serif;font-size:1.15rem;font-weight:400}
.cookie-text a{color:#f3ece0;text-decoration:underline}
.cookie-actions{display:flex;gap:10px}
.cookie-banner .btn-ghost{color:#faf6ef;border-color:#3d3a32}
.cookie-banner .btn-primary{background:#faf6ef;color:#1a1a1a}
.cookie-banner .btn-primary:hover{background:#fff;color:#1a1a1a}

/* Page hero (inner pages) */
.page-hero{padding:80px 0 40px}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{max-width:820px}
.page-hero p{max-width:640px;font-size:1.1rem;color:var(--ink-soft);margin-top:20px}

/* Two col content */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.two-col img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* Process steps */
.process-list{counter-reset:step;display:grid;gap:30px;margin:40px 0 0;list-style:none;padding:0}
.process-list li{counter-increment:step;display:grid;grid-template-columns:80px 1fr;gap:30px;padding:30px 0;border-top:1px solid var(--line);align-items:start}
.process-list li::before{content:counter(step,decimal-leading-zero);font-family:'Instrument Serif',serif;font-size:2.2rem;color:var(--brand-deep)}
.process-list h3{margin-bottom:8px}

/* Team grid */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px}
.team-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.team-card img{aspect-ratio:4/5;object-fit:cover;width:100%}
.team-card .body{padding:22px 24px 26px}
.team-card h3{font-size:1.3rem;margin-bottom:4px}
.team-card .role{color:var(--brand-deep);font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;font-weight:500;margin-bottom:10px}
.team-card p{color:var(--ink-soft);font-size:.92rem;margin:0}

/* FAQ */
.faq{max-width:780px;margin:0 auto}
.faq-item{border-top:1px solid var(--line);padding:0}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:24px 0;font-size:1.15rem;font-family:'Instrument Serif',serif;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq-q::after{content:'+';color:var(--brand-deep);font-size:1.6rem;transition:transform .3s;flex-shrink:0;line-height:1}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;color:var(--ink-soft)}
.faq-item.open .faq-a{max-height:400px}
.faq-a-inner{padding:0 0 24px;font-size:.98rem}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:start}
.contact-info{background:var(--bg-warm);padding:40px;border-radius:var(--radius);border:1px solid var(--line)}
.contact-info h3{margin-bottom:8px}
.contact-info .info-row{padding:18px 0;border-top:1px solid var(--line)}
.contact-info .info-row:first-of-type{border-top:0;padding-top:24px;margin-top:18px}
.contact-info .label{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--muted);margin-bottom:6px;font-weight:600}
.contact-info .value{font-size:1.05rem;color:var(--ink)}
.contact-info a{color:var(--ink)}
.contact-info a:hover{color:var(--brand-deep)}
.contact-form{display:grid;gap:18px}
.contact-form label{display:block;font-size:.85rem;font-weight:500;margin-bottom:6px;color:var(--ink-soft);letter-spacing:.02em}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--paper);border-radius:10px;font-family:inherit;font-size:.95rem;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px rgba(196,101,74,.12)}
.contact-form textarea{min-height:140px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-success{padding:16px 20px;background:#e9f0e2;border:1px solid #b5c5a3;color:#3d4d2e;border-radius:10px;display:none}
.form-success.show{display:block}

/* Legal pages */
.legal-page{max-width:780px;margin:0 auto;padding:40px 0 0}
.legal-page h2{margin-top:50px}
.legal-page h3{margin-top:32px;font-size:1.2rem;font-family:'Inter',sans-serif;font-weight:600}
.legal-page p,.legal-page li{color:var(--ink-soft);font-size:.98rem}
.legal-page ul{padding-left:20px}
.legal-meta{color:var(--muted);font-size:.88rem;margin-bottom:30px;padding-bottom:24px;border-bottom:1px solid var(--line)}

/* Reveal animation */
.reveal{opacity:1;transform:none;transition:opacity .9s cubic-bezier(.2,.7,.3,1),transform .9s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

/* Responsive */
@media (max-width:900px){
  .hero-grid,.why-grid,.two-col,.contact-grid{grid-template-columns:1fr;gap:40px}
  .services-grid{grid-template-columns:1fr}
  .work-grid,.team-grid,.t-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .nav-main{position:fixed;inset:64px 0 auto 0;background:var(--bg);flex-direction:column;padding:24px;gap:18px;border-bottom:1px solid var(--line);transform:translateY(-150%);transition:transform .35s;margin:0}
  .nav-main.open{transform:translateY(0)}
  .nav-toggle{display:flex}
  .nav-cta{display:none}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width:560px){
  .stats-grid,.work-grid,.team-grid,.t-grid,.footer-grid,.form-row{grid-template-columns:1fr}
  section{padding:64px 0}
  .hero{padding:40px 0 60px}
  .cookie-inner{flex-direction:column;align-items:stretch;text-align:left}
  .cookie-actions{justify-content:flex-end}
}
.js .reveal{opacity:0;transform:translateY(28px)}
.js .reveal.in{opacity:1;transform:none}
@media (max-width:480px){
  h1{font-size:1.95rem;line-height:1.15}
  h2{font-size:1.75rem}
  .hero-lede{font-size:1rem}
  .hero{padding:30px 0 50px}
  .nav-wrap{padding:14px 20px;gap:12px}
  .brand-text{font-size:1.1rem}
  .container{padding:0 20px}
}
.hero-grid > *,.why-grid > *,.two-col > *,.contact-grid > *,.footer-grid > *{min-width:0}
.hero-grid h1,.page-hero h1{max-width:100%}
