/* ============================================
   STUDIO ONE3 — Main Stylesheet
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@300;400;500&family=Beau+Rivage&display=swap');

* {
    user-select: none !important;
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    -ms-user-select: none !important;
}

a, button, .btn-solid, .btn-line, .btn-outline,
.p-item, .svc-card, .hero-dot, .nav-menu a,
.sub-menu a, .back-btn, [onclick],
.album-card:not(.no-cursor-card) {
    cursor: pointer !important;
}

input, textarea, select {
    user-select: text !important;
    -webkit-user-select: text !important;
    cursor: text !important;
    outline: revert !important;
    caret-color: auto !important;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --cream:#F7F4EF;--charcoal:#1A1A18;--warm-gray:#8C8C88;
  --accent:#C9A87C;--accent-dark:#b8966a;--white:#FEFEFE;
  --border:rgba(26,26,24,0.10);
}

html{scroll-behavior:smooth;overflow-x:hidden;max-width:100%}
body{font-family:'Jost',sans-serif;background:var(--cream);color:var(--charcoal);overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;background:#1A1A18;border-bottom:1px solid rgba(255,255,255,0.08);transition:background .4s}
.nav-inner{display:flex;flex-direction:column;align-items:center;padding:24px 56px 0}
.nav-logo{font-family:'Beau Rivage','Pinyon Script',cursive !important;font-size:72px;font-weight:400;color:#ffffff !important;transition:color .4s;margin-bottom:8px;text-align:center;padding-top:48px;text-transform:none !important;display:block}
.nav-menu{display:flex;gap:36px;list-style:none;margin:0;padding:0;border-top:1px solid rgba(255,255,255,0.15);padding-top:10px}
.nav-menu li{position:relative;list-style:none}
.nav-menu > li > a{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,0.85);font-weight:400;transition:color .3s}
.nav-menu > li > a:hover{color:var(--accent)}
.nav-menu-btn{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:16px 24px;position:absolute;right:0;top:0}
.nav-menu-btn span{width:22px;height:1px;background:#ffffff;transition:all .3s;display:block}

/* 드롭다운 */
.sub-menu{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);background:rgba(26,26,24,0.4);min-width:180px;padding:8px 0;border-top:2px solid var(--accent);z-index:999;margin:0;list-style:none}
.nav-menu li:hover > .sub-menu{display:block}
.sub-menu li a{display:block;padding:12px 20px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,0.85);white-space:nowrap;transition:color .2s}
.sub-menu li a:hover{color:var(--accent);background:rgba(255,255,255,0.06)}
.sub-menu .menu-item-has-children > .sub-menu{display:none;position:absolute;left:100%;top:0;background:rgba(26,26,24,0.4);min-width:180px;padding:8px 0;border-top:2px solid var(--accent)}
.sub-menu .menu-item-has-children:hover > .sub-menu{display:block}

/* PAGE HERO */
.page-hero{height:55vh;min-height:360px;position:relative;overflow:hidden;display:flex;align-items:flex-end;margin-top:0}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.2) 0%,rgba(0,0,0,.55) 100%)}
.page-hero-content{position:relative;padding:0 56px 56px;color:var(--white)}
.page-eyebrow{font-size:10px;letter-spacing:.3em;text-transform:uppercase;opacity:.7;margin-bottom:12px}
.page-title{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,6vw,72px);font-weight:300;line-height:1.05}
.page-title em{font-style:italic}

/* SECTIONS */
section{padding:96px 56px}
.section-label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;font-weight:500}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,52px);font-weight:300;line-height:1.15}
.section-title em{font-style:italic}

/* BUTTONS */
.btn-line{display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;border-bottom:1px solid currentColor;padding-bottom:5px;transition:opacity .3s}
.btn-line:hover{opacity:.65}
.btn-line::after{content:'→';font-size:13px}
.btn-solid{display:inline-flex;align-items:center;gap:10px;padding:14px 36px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;background:var(--charcoal);color:var(--white);transition:background .3s}
.btn-solid:hover{background:var(--accent)}
.btn-outline{display:inline-flex;align-items:center;gap:10px;padding:13px 34px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--charcoal);color:var(--charcoal);transition:all .3s}
.btn-outline:hover{background:var(--charcoal);color:var(--white)}

/* HOME HERO */
.hero{height:100vh;position:relative;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.8s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.05) 40%,rgba(0,0,0,.5) 100%)}
.hero-content{position:absolute;bottom:88px;left:56px;color:var(--white)}
.hero-eyebrow{font-size:10px;letter-spacing:.3em;text-transform:uppercase;opacity:.7;margin-bottom:20px}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(56px,8vw,108px);font-weight:300;line-height:.95;margin-bottom:36px}
.hero-title em{font-style:italic;display:block}
.hero-dots{position:absolute;bottom:40px;left:56px;display:flex;gap:10px}
.hero-dot{height:1px;background:rgba(255,255,255,.35);cursor:pointer;transition:all .4s;width:28px}
.hero-dot.active{background:var(--white);width:48px}
.hero-counter{position:absolute;right:56px;bottom:88px;color:rgba(255,255,255,.6);font-size:12px;letter-spacing:.2em}

/* PORTFOLIO */
.portfolio{background:var(--white)}
.portfolio-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px}
.portfolio-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.p-item{overflow:hidden;cursor:pointer;position:relative;background:#e8e4dc}
.p-item img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.25,.46,.45,.94);display:block}
.p-item:hover img{transform:scale(1.05)}
.p-item-caption{position:absolute;bottom:0;left:0;right:0;padding:20px 18px 18px;background:linear-gradient(transparent,rgba(0,0,0,.65));color:var(--white);opacity:0;transition:opacity .4s}
.p-item:hover .p-item-caption{opacity:1}
.p-item-tag{font-size:9px;letter-spacing:.22em;text-transform:uppercase;opacity:.75;margin-bottom:4px}
.p-item-name{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:300}
.p1{grid-column:span 7;height:500px}
.p2{grid-column:span 5;height:500px}
.p3{grid-column:span 4;height:310px}
.p4{grid-column:span 4;height:310px}
.p5{grid-column:span 4;height:310px}

/* SERVICES */
.services{background:var(--cream)}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(26,26,24,.08);margin-top:56px}
.svc-card{background:var(--cream);padding:40px 28px 36px;transition:background .35s,color .35s;cursor:pointer}
.svc-card:hover{background:var(--charcoal)}
.svc-num{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;color:rgba(26,26,24,.08);line-height:1;margin-bottom:20px;transition:color .35s}
.svc-card:hover .svc-num{color:rgba(255,255,255,.1)}
.svc-name{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;margin-bottom:10px;transition:color .35s}
.svc-card:hover .svc-name{color:var(--white)}
.svc-desc{font-size:13px;line-height:1.75;color:var(--warm-gray);transition:color .35s}
.svc-card:hover .svc-desc{color:rgba(255,255,255,.55)}

/* ABOUT STRIP */
.about-strip{background:var(--charcoal)}
.about-strip-inner{display:grid;grid-template-columns:1fr 1fr}
.about-img-side{position:relative;min-height:560px;overflow:hidden}
.about-img-side img{width:100%;height:100%;object-fit:cover}
.about-img-accent{position:absolute;bottom:32px;left:32px;width:120px;height:120px;border:1px solid var(--accent);pointer-events:none}
.about-text-side{padding:80px 64px;display:flex;flex-direction:column;justify-content:center}
.about-body{font-size:15px;line-height:1.85;color:rgba(255,255,255,.6);margin-bottom:12px}
.about-stats{display:flex;gap:40px;margin:36px 0}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;color:var(--accent);line-height:1}
.stat-label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:6px}

/* ABOUT PAGE */
.about-intro{background:var(--white);display:grid;grid-template-columns:1fr 1fr}
.about-intro-img{position:relative;min-height:640px;overflow:hidden}
.about-intro-img img{width:100%;height:100%;object-fit:cover}
.about-intro-img-accent{position:absolute;top:40px;right:40px;width:100px;height:100px;border:1px solid var(--accent);pointer-events:none}
.about-intro-text{padding:96px 64px;display:flex;flex-direction:column;justify-content:center}
.about-intro-text p{font-size:15px;line-height:1.9;color:#444;margin-bottom:20px}
.about-intro-text blockquote{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;font-style:italic;line-height:1.45;color:var(--charcoal);border-left:2px solid var(--accent);padding-left:24px;margin:32px 0}
.stats-row{background:var(--charcoal);padding:64px 56px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-block{padding:40px 32px;text-align:center}
.stat-block-num{font-family:'Cormorant Garamond',serif;font-size:64px;font-weight:300;color:var(--accent);line-height:1;margin-bottom:10px}
.stat-block-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.team-section{background:var(--cream)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:52px}
.team-card-img{aspect-ratio:3/4;overflow:hidden;margin-bottom:20px}
.team-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.team-card:hover .team-card-img img{transform:scale(1.04)}
.team-card-name{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;margin-bottom:4px}
.team-card-role{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.team-card-bio{font-size:13px;line-height:1.75;color:var(--warm-gray)}

/* CONTACT PAGE */
.contact-layout{display:grid;grid-template-columns:1fr 1.3fr;min-height:80vh}
.contact-info{background:var(--charcoal);padding:96px 64px;display:flex;flex-direction:column;justify-content:center}
.contact-detail-group{margin-bottom:36px}
.contact-detail-label{font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:8px}
.contact-detail-value{font-size:15px;color:var(--white);line-height:1.7}
.contact-detail-value a{color:var(--white);transition:color .2s}
.contact-detail-value a:hover{color:var(--accent)}
.contact-form-wrap{background:var(--white);padding:96px 72px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.form-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--warm-gray)}
.form-input{width:100%;border:none;border-bottom:1px solid rgba(26,26,24,.15);padding:10px 0;font-family:'Jost',sans-serif;font-size:14px;background:transparent;color:var(--charcoal);outline:none;transition:border-color .3s}
.form-input:focus{border-bottom-color:var(--accent)}
.form-input::placeholder{color:rgba(26,26,24,.25)}
.form-textarea{resize:vertical;min-height:100px}
.form-submit{margin-top:8px;padding:16px 48px;background:var(--charcoal);color:var(--white);border:none;font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:background .3s}
.form-submit:hover{background:var(--accent)}
.wpcf7-form p{margin:0}
.wpcf7-form .wpcf7-text,
.wpcf7-form .wpcf7-email,
.wpcf7-form .wpcf7-tel,
.wpcf7-form .wpcf7-date,
.wpcf7-form .wpcf7-select,
.wpcf7-form .wpcf7-textarea{width:100%;padding:14px 0;background:transparent;border:none;border-bottom:1px solid var(--border);font-family:'Jost',sans-serif;font-size:14px;color:var(--charcoal);outline:none;transition:border-color .3s;margin-bottom:4px;display:block;box-sizing:border-box}
.wpcf7-form .wpcf7-textarea{height:120px;resize:none}
.wpcf7-form .form-label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--warm-gray);display:block;margin-bottom:4px;margin-top:20px}
.wpcf7-form .form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.wpcf7-form input[type="submit"],.wpcf7-form .wpcf7-submit{background:var(--charcoal);color:var(--white);border:none;padding:14px 40px;font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;transition:background .3s;margin-top:24px}
.wpcf7-form input[type="submit"]:hover,.wpcf7-form .wpcf7-submit:hover{background:var(--accent)}
.wpcf7-response-output{margin-top:16px !important;font-size:13px;padding:8px 0 !important;border:none !important}
.wpcf7-not-valid-tip{font-size:11px;color:#c0392b;margin-top:4px;display:block}

/* CTA STRIP */
.cta-strip{background:var(--charcoal);padding:72px 56px;display:flex;justify-content:space-between;align-items:center;gap:40px}
.cta-strip-title{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,3.5vw,44px);font-weight:300;color:var(--white)}
.cta-strip-title em{font-style:italic;color:var(--accent)}

/* FOOTER */
footer{background:#111110;color:rgba(255,255,255,.45);padding:56px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;color:var(--white);letter-spacing:.15em;margin-bottom:12px}
.footer-tagline{font-size:12px;line-height:1.7}
.footer-col-title{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:16px;display:block}
.footer-col a,.footer-col p{font-size:13px;line-height:2;color:rgba(255,255,255,.45);display:block;transition:color .2s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid rgba(255,255,255,.07);font-size:11px}
.footer-social{display:flex;gap:20px}
.footer-social a{font-size:11px;letter-spacing:.1em;color:rgba(255,255,255,.45);transition:color .2s}
.footer-social a:hover{color:var(--white)}

/* ABOUT 스크립트 제목 */
.script-title{font-family:'Beau Rivage',cursive !important;font-size:0.9em;font-weight:400;text-transform:none !important;letter-spacing:.05em}

/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* RESPONSIVE */
@media(max-width:900px){
  .nav-inner{padding:0 24px}
  .nav-logo{font-size:42px !important;padding-top:20px !important;margin-bottom:6px !important}
  .nav-menu{gap:16px;padding-top:8px}
  .nav-menu > li > a{font-size:11px}
  .nav-menu-btn{display:flex;top:12px;right:16px}
  section{padding:64px 24px}
  .page-hero{height:35vh !important;min-height:200px !important}
  .page-hero-content{padding:0 24px 40px}
  .hero-content{left:24px;bottom:72px}
  .hero-dots{left:24px}
  .hero-counter{display:none}
  .portfolio-grid{grid-template-columns:1fr 1fr}
  .p1,.p2,.p3,.p4,.p5{grid-column:span 1;height:220px}
  .services-grid{grid-template-columns:1fr !important}
  .services{padding:48px 24px}
  .about-strip-inner,.about-intro,.contact-layout{grid-template-columns:1fr}
  .about-img-side,.about-intro-img{min-height:320px}
  .about-text-side{padding:56px 24px}
  .about-intro-text{padding:56px 24px}
  .contact-info{padding:64px 24px}
  .contact-form-wrap{padding:64px 24px}
  .form-row-2{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .cta-strip{flex-direction:column;text-align:center;padding:56px 24px}
  footer{padding:48px 24px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:16px;text-align:center}

  /* 모바일 메뉴 */
  .nav-menu{
    display:none;
    flex-direction:column;
    position:fixed;
    top:0;left:0;
    width:100%;height:100%;
    background:#0f0f0e;
    z-index:99999;
    padding:100px 32px 40px;
    overflow-y:auto;
    gap:0;
  }
  .nav-menu.open{display:flex}
  .nav-menu > li{
    border-bottom:1px solid rgba(255,255,255,0.08);
    padding:16px 0;
    list-style:none;
  }
  .nav-menu > li > a{
    font-size:14px !important;
    letter-spacing:0.16em;
    text-transform:uppercase;
    color:#ffffff !important;
    font-family:'Jost',sans-serif;
    text-decoration:none;
  }
  .sub-menu{
    position:static !important;
    transform:none !important;
    background:#0f0f0e !important;
    border:none !important;
    border-left:2px solid var(--accent) !important;
    margin:12px 0 0 16px !important;
    padding:4px 0 !important;
    display:none !important;
    box-shadow:none !important;
    z-index:auto !important;
    min-width:auto !important;
  }
  .sub-menu.open{display:block !important}
  .sub-menu li a{
    padding:10px 16px !important;
    font-size:12px !important;
    color:#ffffff !important;
    white-space:normal !important;
  }
  .sub-menu .sub-menu{
    left:0 !important;
    margin-left:16px !important;
    border-top:none !important;
  }
  .nav-menu li:hover > .sub-menu{display:none !important}
}

@media(max-width:560px){
  .team-grid{grid-template-columns:1fr}
}