/* Knack Films — cinematic dark theme. All colors HSL. */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@200;300;400;500;600;700;800&family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600;9..144,700&display=swap');

:root{
  --background: 0 0% 4%;
  --foreground: 40 20% 96%;
  --card: 0 0% 6%;
  --primary: 36 90% 56%;
  --primary-foreground: 0 0% 6%;
  --secondary: 0 0% 10%;
  --muted: 0 0% 10%;
  --muted-foreground: 40 8% 65%;
  --border: 0 0% 14%;
  --gradient-hero: linear-gradient(180deg, hsl(0 0% 0% / .2) 0%, hsl(0 0% 0% / .5) 50%, hsl(0 0% 4%) 100%);
  --container: 1280px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:hsl(var(--background));
  color:hsl(var(--foreground));
  font-family:'Manrope',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'ss01','cv11';
  line-height:1.6;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5,h6{font-family:'Fraunces',Georgia,serif;font-weight:400;letter-spacing:-.02em;line-height:1.05;margin:0 0 .5em}
::selection{background:hsl(var(--primary)/.4)}
hr{border:0;border-top:1px solid hsl(var(--border));margin:0}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.3em;color:hsl(var(--muted-foreground));font-weight:500}
.display-xl{font-family:'Fraunces',serif;font-size:clamp(3rem,9vw,9rem);line-height:.95;letter-spacing:-.02em}
.display-lg{font-family:'Fraunces',serif;font-size:clamp(2.5rem,6vw,6rem);line-height:.95;letter-spacing:-.02em}
.display-md{font-family:'Fraunces',serif;font-size:clamp(1.75rem,3.5vw,3.5rem);line-height:1.05}
.text-primary{color:hsl(var(--primary))}
.text-muted{color:hsl(var(--muted-foreground))}
em.accent{font-style:normal;color:hsl(var(--primary))}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:12px;padding:18px 28px;font-size:12px;text-transform:uppercase;letter-spacing:.25em;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .35s cubic-bezier(.65,0,.35,1)}
.btn-primary{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-color:hsl(var(--primary))}
.btn-primary:hover{background:transparent;color:hsl(var(--primary))}
.btn-ghost{background:transparent;color:hsl(var(--foreground));border-color:hsl(var(--border))}
.btn-ghost:hover{border-color:hsl(var(--primary));color:hsl(var(--primary))}
.btn .arrow{transition:transform .35s}
.btn:hover .arrow{transform:translateX(4px)}

/* Header */
.site-header{position:fixed;inset:0 0 auto 0;z-index:50;transition:all .5s;border-bottom:1px solid transparent}
.site-header.scrolled{background:hsl(var(--background)/.85);backdrop-filter:blur(16px);border-bottom-color:hsl(var(--border)/.6)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:80px}
.site-header .logo img{height:40px;width:auto;filter:invert(1) brightness(1.1)}
.main-nav{display:none;gap:4px}
.main-nav a{padding:8px 16px;font-size:13px;text-transform:uppercase;letter-spacing:.18em;color:hsl(var(--muted-foreground));font-weight:500;position:relative;transition:color .3s}
.main-nav a:hover,.main-nav a.current-menu-item,.main-nav .current-menu-item > a{color:hsl(var(--foreground))}
.main-nav a.current-menu-item::after,.main-nav .current-menu-item > a::after{content:"";position:absolute;left:16px;right:16px;bottom:-2px;height:1px;background:hsl(var(--primary))}
.header-cta{display:none}
.menu-toggle{background:none;border:0;color:inherit;cursor:pointer;padding:10px}
@media(min-width:900px){
  .main-nav{display:flex}
  .header-cta{display:inline-flex}
  .menu-toggle{display:none}
}
.mobile-drawer{display:none;background:hsl(var(--background));border-top:1px solid hsl(var(--border)/.6);padding:24px}
.mobile-drawer.open{display:block}
.mobile-drawer a{display:block;padding:20px 0;border-bottom:1px solid hsl(var(--border)/.4);font-family:'Fraunces',serif;font-size:28px}

/* Hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-top:128px;padding-bottom:80px;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-1}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:kenburns 20s ease-in-out infinite alternate}
.hero-overlay{position:absolute;inset:0;background:var(--gradient-hero)}
.vignette{position:absolute;inset:0;box-shadow:inset 0 0 200px 40px hsl(0 0% 0% / .7);pointer-events:none}
.grain{position:absolute;inset:0;pointer-events:none;opacity:.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-meta{display:flex;align-items:center;gap:16px;margin-bottom:40px}
.hero-meta .rule{height:1px;width:48px;background:hsl(var(--primary))}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:40px}
.hero-row{display:flex;flex-direction:column;gap:40px;margin-top:40px}
@media(min-width:900px){.hero-row{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.hero p.lead{max-width:480px;color:hsl(var(--muted-foreground));font-size:18px;line-height:1.6}

/* Sections */
.section{padding:96px 0}
.section-lg{padding:128px 0}
.section-title{max-width:18ch;margin-bottom:32px}
.two-col{display:grid;gap:64px}
@media(min-width:900px){.two-col{grid-template-columns:1.1fr 1fr;gap:96px;align-items:center}}

/* Service grid */
.services{display:grid;gap:1px;background:hsl(var(--border));border:1px solid hsl(var(--border))}
@media(min-width:700px){.services{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.services{grid-template-columns:repeat(3,1fr)}}
.service{background:hsl(var(--background));padding:48px;transition:background .4s,transform .4s}
.service:hover{background:hsl(var(--card));transform:translateY(-4px)}
.service .num{font-family:'Fraunces',serif;color:hsl(var(--primary));font-size:14px;letter-spacing:.2em}
.service h3{font-size:32px;margin:24px 0 16px}
.service p{color:hsl(var(--muted-foreground));font-size:15px}

/* Mission */
.mission{background:hsl(var(--card));padding:96px 0;position:relative;overflow:hidden}
.mission::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,hsl(var(--primary)/.08),transparent 60%)}
.mission .container{position:relative}

/* Portfolio CTA */
.cta{position:relative;padding:128px 0;overflow:hidden;text-align:center}
.cta-bg{position:absolute;inset:0;z-index:-1}
.cta-bg img{width:100%;height:100%;object-fit:cover;opacity:.4}
.cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,hsl(var(--background)/.6),hsl(var(--background)))}

/* Portfolio grid (used by plugin shortcode) */
.kf-portfolio{display:grid;gap:24px;grid-template-columns:1fr}
@media(min-width:900px){.kf-portfolio{grid-template-columns:repeat(12,1fr);gap:32px}}
.kf-card{position:relative;display:block;overflow:hidden;background:hsl(var(--secondary));grid-column:span 12}
.kf-card.span-7{grid-column:span 12}
.kf-card.span-5{grid-column:span 12}
@media(min-width:900px){.kf-card.span-7{grid-column:span 7}.kf-card.span-5{grid-column:span 5}}
.kf-card .ratio{aspect-ratio:16/10;overflow:hidden}
.kf-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.5s cubic-bezier(.16,1,.3,1)}
.kf-card:hover img{transform:scale(1.1)}
.kf-card .veil{position:absolute;inset:0;background:linear-gradient(to top,hsl(var(--background)/.95),transparent);opacity:.85;transition:opacity .5s}
.kf-card:hover .veil{opacity:1}
.kf-card .play{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .5s}
.kf-card:hover .play{opacity:1}
.kf-card .play span{display:grid;place-items:center;width:80px;height:80px;border-radius:50%;border:1px solid hsl(var(--primary));background:hsl(var(--background)/.3);backdrop-filter:blur(8px);color:hsl(var(--primary));font-size:28px}
.kf-card .meta{position:absolute;inset:auto 0 0 0;padding:24px 32px;display:flex;justify-content:space-between;align-items:flex-end;gap:24px}
.kf-card .meta h3{font-size:24px;margin:8px 0 4px}
.kf-card .meta .client{color:hsl(var(--muted-foreground));font-size:14px}

/* Filter bar */
.kf-filter{position:sticky;top:80px;z-index:30;background:hsl(var(--background)/.6);backdrop-filter:blur(8px);border-top:1px solid hsl(var(--border));border-bottom:1px solid hsl(var(--border))}
.kf-filter .row{display:flex;flex-wrap:wrap;gap:8px;padding:16px 0}
.kf-filter button{background:none;border:0;color:hsl(var(--muted-foreground));padding:8px 16px;text-transform:uppercase;letter-spacing:.22em;font-size:12px;cursor:pointer;font-weight:500}
.kf-filter button.active{color:hsl(var(--primary))}
.kf-filter button.active::after{content:"";display:block;height:1px;background:hsl(var(--primary));margin-top:4px}

/* Contact form */
.contact-form{display:grid;gap:20px;max-width:640px}
.contact-form input,.contact-form textarea,.contact-form select{
  background:hsl(var(--secondary));border:1px solid hsl(var(--border));color:hsl(var(--foreground));
  padding:18px 20px;font-family:inherit;font-size:15px;width:100%;transition:border-color .3s
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:hsl(var(--primary))}
.contact-form textarea{min-height:160px;resize:vertical}
.contact-form label{font-size:11px;text-transform:uppercase;letter-spacing:.25em;color:hsl(var(--muted-foreground));margin-bottom:8px;display:block}
.form-msg{padding:16px 20px;background:hsl(var(--card));border-left:2px solid hsl(var(--primary));color:hsl(var(--foreground));font-size:14px}
.form-msg.error{border-left-color:hsl(0 72% 51%)}

/* Footer */
.site-footer{position:relative;border-top:1px solid hsl(var(--border));background:hsl(var(--background));padding:80px 0 32px;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,hsl(var(--primary)/.4),transparent)}
.footer-top{display:flex;flex-direction:column;gap:24px;border-bottom:1px solid hsl(var(--border));padding-bottom:64px;margin-bottom:64px}
@media(min-width:900px){.footer-top{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.footer-grid{display:grid;gap:48px;grid-template-columns:1fr}
@media(min-width:900px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.footer-grid img{height:36px;width:auto;filter:invert(1) brightness(1.1)}
.footer-grid p{color:hsl(var(--muted-foreground));font-size:14px;max-width:380px;margin-top:24px}
.socials{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.socials a{display:grid;place-items:center;width:56px;height:56px;border:1px solid hsl(var(--border));background:hsl(var(--secondary)/.4);color:inherit;transition:all .3s}
.socials a:hover{background:hsl(var(--primary));color:hsl(var(--primary-foreground));border-color:hsl(var(--primary));transform:translateY(-4px)}
.footer-grid h4{font-family:'Manrope',sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.3em;color:hsl(var(--muted-foreground));margin-bottom:20px;font-weight:500}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:12px;font-size:14px;color:hsl(var(--muted-foreground))}
.footer-grid li a:hover{color:hsl(var(--primary))}
.footer-bottom{margin-top:64px;padding-top:32px;border-top:1px solid hsl(var(--border));display:flex;flex-direction:column;gap:12px;font-size:12px;color:hsl(var(--muted-foreground))}
@media(min-width:900px){.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}}
.footer-bottom .tag{text-transform:uppercase;letter-spacing:.25em}

/* Animations */
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.12)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* Stats */
.stats{display:grid;gap:32px;grid-template-columns:repeat(2,1fr)}
@media(min-width:700px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat .num{font-family:'Fraunces',serif;font-size:clamp(2.5rem,5vw,4rem);color:hsl(var(--primary));line-height:1}
.stat .lbl{margin-top:12px;font-size:12px;text-transform:uppercase;letter-spacing:.25em;color:hsl(var(--muted-foreground))}
