/*
Theme Name: Sahr Studio
Theme URI: https://sahrstudio.id
Author: Sahr Studio Team
Author URI: https://sahrstudio.id
Description: A minimalist, high-end agency portfolio theme with smooth transitions and dual-language support.
Version: 1.0
Text Domain: sahr-studio
*/

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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#080808;--fg:#f5f5f0;--muted:#5a5a5a;--dim:#141414;--border:rgba(245,245,240,0.08);
  --font:'Space Grotesk',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--font);font-size:16px;line-height:1.6;overflow-x:hidden;cursor:none}
::-webkit-scrollbar{width:2px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#333}
.cursor{width:7px;height:7px;background:var(--fg);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s}
.cursor-ring{width:32px;height:32px;border:1px solid rgba(245,245,240,0.35);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s}

/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1.8rem 3.5rem;background:linear-gradient(to bottom,rgba(8,8,8,0.98) 0%,transparent 100%)}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.nav-logo img{height:28px;width:auto;filter:brightness(1)}
.nav-logo-text{font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--fg)}
.nav-links{display:flex;gap:2.5rem;list-style:none;align-items:center}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;transition:color .3s;cursor:none}
.nav-links a:hover,.nav-links a.active{color:var(--fg)}
.nav-right{display:flex;align-items:center;gap:1.5rem}
.lang-toggle{display:flex;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:2px;overflow:hidden}
.lang-btn{padding:.4rem .9rem;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;font-family:var(--font);color:var(--muted);background:transparent;border:none;cursor:pointer;transition:all .2s}
.lang-btn.active{background:var(--fg);color:var(--bg)}
.nav-cta{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--fg);text-decoration:none;border:1px solid rgba(245,245,240,0.3);padding:.55rem 1.3rem;transition:background .3s,color .3s;cursor:none}
.nav-cta:hover{background:var(--fg);color:var(--bg)}

/* ===== PAGES ===== */
.page{display:none;min-height:100vh}
.page.active{display:block}

/* ===== HERO ===== */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 3.5rem 5.5rem;position:relative;overflow:hidden}
.hero-ghost{position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);font-size:clamp(6rem,16vw,18rem);font-weight:700;letter-spacing:-.06em;color:transparent;-webkit-text-stroke:1px rgba(245,245,240,0.04);white-space:nowrap;pointer-events:none;user-select:none}
.hero-eyebrow{font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:1.8rem}
.hero-title{font-size:clamp(2.8rem,6.5vw,6.2rem);font-weight:300;line-height:1.02;letter-spacing:-.03em;max-width:14ch;margin-bottom:3.5rem}
.hero-title em{font-style:italic}
.hero-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem}
.hero-desc{max-width:32ch;font-size:.9rem;color:var(--muted);line-height:1.75}
.hero-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}
.hero-stat{text-align:right}
.hero-stat-num{font-size:2rem;font-weight:600;letter-spacing:-.04em;display:block}
.hero-stat-label{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.divider-h{width:1px;height:40px;background:var(--border);margin:0 auto}

/* ===== MARQUEE ===== */
.marquee-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.2rem 0;overflow:hidden;margin:6rem 0}
.marquee-track{display:flex;gap:4rem;animation:marquee 22s linear infinite;width:max-content;white-space:nowrap}
.marquee-item{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:2rem}
.m-dot{width:3px;height:3px;border-radius:50%;background:var(--muted)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== SECTION COMMON ===== */
.section{padding:8rem 3.5rem}
.sec-label{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.8rem;margin-bottom:3rem}
.sec-label::before{content:'';width:20px;height:1px;background:var(--muted)}
.sec-title{font-size:clamp(2rem,4vw,3.2rem);font-weight:300;letter-spacing:-.025em;line-height:1.15}
.sec-title strong{font-weight:600}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:6rem;align-items:end}
.about-body{font-size:.95rem;color:var(--muted);line-height:1.85;margin-bottom:2.5rem}
.stats-row{display:flex;gap:2.5rem;border-top:1px solid var(--border);padding-top:2rem;margin-top:2rem}
.stat-num{font-size:2.2rem;font-weight:600;letter-spacing:-.04em;display:block}
.stat-lbl{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
.value-list{margin-top:2.5rem;list-style:none}
.value-item{padding:1rem 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1.2rem;font-size:.85rem;color:var(--muted)}
.value-item::before{content:'→';color:var(--fg);font-size:.8rem}

/* ===== SERVICES ===== */
.services-intro{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:5rem}
.services-intro-desc{font-size:.9rem;color:var(--muted);line-height:1.8;margin-top:1rem}
.svc-list{list-style:none;border-top:1px solid var(--border)}
.svc-item{border-bottom:1px solid var(--border);display:grid;grid-template-columns:2.5rem 1fr auto;gap:1.5rem;align-items:center;padding:2rem 0;transition:padding .4s cubic-bezier(.23,1,.32,1),background .3s;cursor:default}
.svc-item:hover{padding-left:1.2rem;padding-right:1.2rem;background:rgba(245,245,240,0.02)}
.svc-num{font-size:.65rem;color:var(--muted);letter-spacing:.08em;font-weight:500}
.svc-name{font-size:clamp(1rem,2.2vw,1.5rem);font-weight:400;letter-spacing:-.01em;transition:letter-spacing .4s}
.svc-item:hover .svc-name{letter-spacing:.02em}
.svc-tags{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}
.tag{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:.25rem .7rem;transition:border-color .3s,color .3s}
.svc-item:hover .tag{border-color:rgba(245,245,240,0.2);color:var(--fg)}

/* ===== PORTFOLIO ===== */
.portfolio-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;margin-top:3rem}
.p-card{position:relative;overflow:hidden;background:var(--dim);cursor:none}
.p-card.large{grid-column:span 7;aspect-ratio:4/3}
.p-card.small{grid-column:span 5;aspect-ratio:4/3}
.p-card.wide{grid-column:span 5;aspect-ratio:16/9}
.p-card.med{grid-column:span 7;aspect-ratio:16/9}
.p-card.full{grid-column:span 6;aspect-ratio:4/3}
.p-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .7s cubic-bezier(.23,1,.32,1);position:relative}
.p-card:hover .p-inner{transform:scale(1.05)}
.p-ghost{font-size:4.5rem;font-weight:700;letter-spacing:-.05em;opacity:.05;user-select:none}
.p-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.p-upload-label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--muted);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;border:1px dashed rgba(245,245,240,0.12);transition:border-color .3s,color .3s;cursor:pointer}
.p-upload-label:hover{border-color:rgba(245,245,240,0.3);color:var(--fg)}
.p-upload-icon{font-size:1.8rem;opacity:.3}
.p-card input[type=file]{display:none}
.p-overlay{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;background:linear-gradient(transparent,rgba(8,8,8,.92));transform:translateY(100%);transition:transform .4s cubic-bezier(.23,1,.32,1)}
.p-card:hover .p-overlay{transform:translateY(0)}
.p-title{font-size:.95rem;font-weight:500;margin-bottom:.2rem}
.p-cat{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ===== BRANDS ===== */
.brands-marquee{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:2rem 0;overflow:hidden;margin-top:5rem}
.brands-track{display:flex;gap:4rem;animation:marquee 20s linear infinite;width:max-content;align-items:center}
.brand-logo{height:28px;display:flex;align-items:center;justify-content:center;opacity:.35;transition:opacity .3s;filter:brightness(10)}
.brand-logo:hover{opacity:.9}
.brand-name{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg);font-weight:600;padding:0 1rem}

/* ===== PROCESS ===== */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--border);margin-top:4rem}
.proc-step{padding:2.5rem 2rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .3s}
.proc-step:hover{background:rgba(245,245,240,0.02)}
.proc-num{font-size:.6rem;letter-spacing:.2em;color:var(--muted);display:block;margin-bottom:2.5rem}
.proc-title{font-size:1.1rem;font-weight:500;margin-bottom:.75rem;letter-spacing:-.01em}
.proc-desc{font-size:.8rem;color:var(--muted);line-height:1.75}

/* ===== CTA ===== */
.cta-section{text-align:center;padding:9rem 3.5rem;border-top:1px solid var(--border);position:relative;overflow:hidden}
.cta-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(245,245,240,0.025) 0%,transparent 65%);pointer-events:none}
.cta-eyebrow{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem}
.cta-title{font-size:clamp(2.5rem,7vw,6rem);font-weight:300;letter-spacing:-.04em;line-height:.95;margin-bottom:2.5rem}
.cta-title em{font-style:italic}
.cta-btn{display:inline-block;border:1px solid var(--fg);color:var(--fg);text-decoration:none;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:1.1rem 2.8rem;font-family:var(--font);background:transparent;transition:background .3s,color .3s;cursor:none}
.cta-btn:hover{background:var(--fg);color:var(--bg)}

/* ===== CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;margin-top:3rem}
.contact-info h3{font-size:1.4rem;font-weight:400;margin-bottom:2rem;letter-spacing:-.015em}
.contact-detail{margin-bottom:1.8rem}
.contact-detail .label{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;display:block}
.contact-detail .val{font-size:1rem;color:var(--fg)}
.contact-detail a{color:var(--fg);text-decoration:none;transition:opacity .3s}
.contact-detail a:hover{opacity:.6}
.socials{display:flex;gap:1rem;margin-top:2.5rem}
.social-btn{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:.5rem 1.1rem;text-decoration:none;transition:all .3s;cursor:none}
.social-btn:hover{border-color:var(--fg);color:var(--fg)}
.contact-form{display:flex;flex-direction:column;gap:1.5rem}
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-label{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.form-input,.form-textarea{background:transparent;border:1px solid var(--border);color:var(--fg);font-family:var(--font);font-size:.9rem;padding:.9rem 1rem;outline:none;transition:border-color .3s;resize:none;cursor:none}
.form-input:focus,.form-textarea:focus{border-color:rgba(245,245,240,0.4)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--muted)}
.form-textarea{min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.submit-btn{background:var(--fg);color:var(--bg);border:none;font-family:var(--font);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:1.1rem 2rem;cursor:pointer;transition:opacity .3s;text-align:center;margin-top:.5rem}
.submit-btn:hover{opacity:.85}
.form-note{font-size:.72rem;color:var(--muted);margin-top:.5rem}

/* ===== PORTFOLIO PAGE ===== */
.portfolio-filter{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:3.5rem;margin-top:2rem}
.filter-btn{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:.45rem 1.1rem;background:transparent;font-family:var(--font);cursor:pointer;transition:all .3s}
.filter-btn:hover,.filter-btn.active{border-color:var(--fg);color:var(--fg)}
.portfolio-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.pf-card{position:relative;overflow:hidden;background:var(--dim);aspect-ratio:4/3;cursor:none}
.pf-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .7s cubic-bezier(.23,1,.32,1)}
.pf-card:hover .pf-inner{transform:scale(1.05)}
.pf-ghost{font-size:3.5rem;font-weight:700;letter-spacing:-.05em;opacity:.06;user-select:none}
.pf-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.pf-upload{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;color:var(--muted);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;border:1px dashed rgba(245,245,240,0.1);cursor:pointer;transition:all .3s}
.pf-upload:hover{border-color:rgba(245,245,240,0.3);color:var(--fg)}
.pf-card input[type=file]{display:none}
.pf-info{position:absolute;bottom:0;left:0;right:0;padding:1.2rem;background:linear-gradient(transparent,rgba(8,8,8,.9));transform:translateY(100%);transition:transform .4s}
.pf-card:hover .pf-info{transform:translateY(0)}
.pf-title{font-size:.85rem;font-weight:500;margin-bottom:.15rem}
.pf-cat{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ===== FOOTER ===== */
footer{border-top:1px solid var(--border);padding:2.5rem 3.5rem;display:flex;justify-content:space-between;align-items:center}
.foot-logo{font-size:.8rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}
.foot-copy{font-size:.65rem;color:var(--muted);letter-spacing:.05em}
.foot-links{display:flex;gap:2rem;list-style:none}
.foot-links a{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .3s;cursor:none}
.foot-links a:hover{color:var(--fg)}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(35px);transition:opacity .85s cubic-bezier(.23,1,.32,1),transform .85s cubic-bezier(.23,1,.32,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}
