*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#fff;--fg:#0a0a0a;--muted:#666;--line:#eee;--alt:#fafafa;
--sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
--serif:Georgia,"Times New Roman",serif}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--fg);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none}

.container{max-width:1160px;margin:0 auto;padding:0 24px}
.section{padding:90px 0}
.section--alt{background:var(--alt)}
.section--dark{background:var(--fg);color:#fff}
.section__head{margin-bottom:48px;max-width:680px}
.section__head h2,.contact h2,.about h2{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:500;line-height:1.15;letter-spacing:-.02em}
.eyebrow{font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#888;margin-bottom:14px}
.section--dark .eyebrow{color:#999}

.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:60px}
.nav__logo{font-weight:700;font-size:.95rem;letter-spacing:-.02em}
.nav__logo span{font-weight:300;color:#888}
.nav__links{display:flex;gap:28px;align-items:center}
.nav__links a{font-size:.88rem;font-weight:500;transition:opacity .2s}
.nav__links a:hover{opacity:.6}
.nav__toggle{display:none;flex-direction:column;gap:5px}
.nav__toggle span{width:22px;height:2px;background:var(--fg)}

.btn{display:inline-flex;align-items:center;gap:6px;padding:12px 22px;background:var(--fg);color:#fff;font-size:.88rem;font-weight:500;border-radius:100px;transition:transform .2s,background .2s}
.btn:hover{background:#2a2a2a;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--fg);border:1px solid var(--fg)}
.btn--ghost:hover{background:var(--fg);color:#fff}
.btn--small{padding:8px 16px;font-size:.82rem}
.btn--full{width:100%;justify-content:center;padding:16px}

.hero{padding:140px 0 70px}
.hero__title{font-family:var(--serif);font-size:clamp(2.2rem,6vw,4.5rem);font-weight:500;line-height:1.05;letter-spacing:-.03em;margin-bottom:24px;max-width:900px}
.hero__title em{font-style:italic;font-weight:400}
.hero__sub{font-size:1.05rem;color:var(--muted);max-width:560px;margin-bottom:32px}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:60px}
.hero__meta{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-top:32px;border-top:1px solid var(--line);max-width:640px}
.hero__meta strong{font-family:var(--serif);font-size:1.7rem;font-weight:500;display:block}
.hero__meta span{font-size:.82rem;color:#888}

.services{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.service{padding:32px;border:1px solid var(--line);border-radius:18px;transition:transform .3s,border-color .3s}
.service:hover{transform:translateY(-4px);border-color:var(--fg)}
.service--dark{background:var(--fg);color:#fff;border-color:var(--fg)}
.service--dark:hover{background:#1a1a1a}
.service__num{font-family:var(--serif);font-size:.9rem;color:#888;margin-bottom:20px}
.service h3{font-family:var(--serif);font-size:1.4rem;font-weight:500;margin-bottom:10px}
.service p{color:var(--muted);font-size:.95rem}
.service--dark p{color:#aaa}

.works{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.work{display:block;transition:transform .3s}
.work:hover{transform:translateY(-6px)}
.work__img{aspect-ratio:4/3;border-radius:14px;overflow:hidden;margin-bottom:14px;display:flex;align-items:center;justify-content:center;color:#fff}
.work__img span{font-family:var(--serif);font-size:2.6rem;font-style:italic;opacity:.4}
.work h3{font-family:var(--serif);font-size:1.25rem;font-weight:500;margin-bottom:2px}
.work p{color:var(--muted);font-size:.88rem}

.process{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.process li{padding-top:24px;border-top:1px solid var(--fg)}
.process li>span{font-family:var(--serif);font-size:.9rem;color:#888;display:block;margin-bottom:16px}
.process h3{font-family:var(--serif);font-size:1.15rem;font-weight:500;margin-bottom:8px}
.process p{font-size:.9rem;color:var(--muted)}

.about{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center}
.about p{color:#bbb;margin:16px 0;font-size:1rem}
.about h2{margin-bottom:8px}
.about__visual{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;max-width:260px;margin:0 auto}
.about__circle{position:absolute;inset:0;border:1px solid #333;border-radius:50%;animation:spin 30s linear infinite}
.about__circle::before{content:"";position:absolute;width:10px;height:10px;background:#fff;border-radius:50%;top:-5px;left:50%;transform:translateX(-50%)}
@keyframes spin{to{transform:rotate(360deg)}}
.about__initials{font-family:var(--serif);font-size:4.5rem;font-style:italic}

.contact{max-width:640px;margin:0 auto;text-align:center}
.contact h2{margin-bottom:12px}
.contact__sub{color:var(--muted);margin-bottom:40px}
.form{display:flex;flex-direction:column;gap:18px;text-align:left;margin-bottom:32px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form label{display:flex;flex-direction:column;gap:6px}
.form span{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:#888}
.form input,.form textarea{font:inherit;padding:12px 0;border:none;border-bottom:1px solid #ddd;background:transparent;outline:none;transition:border-color .2s;resize:vertical}
.form input:focus,.form textarea:focus{border-color:var(--fg)}
.contact__direct{display:flex;justify-content:center;gap:12px;font-size:.92rem;color:var(--muted)}
.contact__direct a:hover{color:var(--fg)}

.footer{padding:32px 0;border-top:1px solid var(--line)}
.footer__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.85rem;color:#888}
.footer__logo{font-weight:700;color:var(--fg);font-size:.95rem}
.footer__logo span{font-weight:300;color:#888}
.footer__links{display:flex;gap:20px}
.footer__links a:hover{color:var(--fg)}

@media (max-width:820px){
  .section{padding:64px 0}
  .nav__links{display:none}
  .nav__toggle{display:flex}
  .hero{padding:110px 0 40px}
  .hero__meta{grid-template-columns:1fr;gap:14px}
  .services,.works{grid-template-columns:1fr}
  .process{grid-template-columns:1fr 1fr}
  .about{grid-template-columns:1fr;gap:32px}
  .form__row{grid-template-columns:1fr}
}
@media (max-width:480px){.process{grid-template-columns:1fr}}

/* === HERO GRID === */
.hero__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;margin-bottom:60px}
.hero__text .hero__cta{margin-bottom:0}
.hero__image{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:5/6;background:#0a0a0a}
.hero__image img{width:100%;height:100%;object-fit:cover;display:block}
.hero__badge{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.95);color:#0a0a0a;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:8px 14px;border-radius:100px;display:flex;align-items:center;gap:8px}
.hero__badge::before{content:"";width:8px;height:8px;background:#10b981;border-radius:50%;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* === WORK IMAGES === */
.work__img img{width:100%;height:100%;object-fit:cover}

/* === ABOUT IMAGE === */
.about__visual{position:relative;aspect-ratio:1;max-width:340px;margin:0 auto;border-radius:18px;overflow:hidden;background:#1a1a1a}
.about__visual img{width:100%;height:100%;object-fit:cover;display:block}

@media (max-width:820px){
  .hero__grid{grid-template-columns:1fr;gap:32px;margin-bottom:40px}
  .hero__image{aspect-ratio:4/3;max-height:400px}
}

/* === LEGAL PAGES === */
.legal{padding:140px 0 90px;max-width:780px}
.legal h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:500;letter-spacing:-.02em;margin-bottom:32px}
.legal h2{font-family:var(--serif);font-size:1.4rem;font-weight:500;margin:40px 0 12px}
.legal h3{font-family:var(--sans);font-size:1.05rem;font-weight:600;margin:24px 0 8px}
.legal p,.legal li{color:#333;font-size:.98rem;margin-bottom:12px;line-height:1.7}
.legal ul{padding-left:20px;margin-bottom:16px}
.legal li{list-style:disc;margin-bottom:6px}
.legal a{text-decoration:underline;text-underline-offset:3px}
.legal a:hover{opacity:.7}
.legal__back{display:inline-flex;align-items:center;gap:6px;margin-bottom:32px;font-size:.88rem;color:#666}
.legal__back:hover{color:var(--fg)}
.legal__updated{font-size:.85rem;color:#888;margin-top:48px;padding-top:24px;border-top:1px solid var(--line)}

/* === FORM CHECKBOX === */
.form__check{flex-direction:row !important;align-items:flex-start;gap:10px !important;cursor:pointer}
.form__check input{margin-top:4px;width:16px;height:16px;flex-shrink:0;accent-color:var(--fg)}
.form__check-text{font-size:.85rem !important;color:var(--muted) !important;letter-spacing:0 !important;text-transform:none !important;line-height:1.5;font-weight:400 !important}
.form__check-text a{text-decoration:underline;color:var(--fg)}
.form__note{font-size:.78rem;color:#888;line-height:1.5;margin-top:-6px}

/* === COOKIE BANNER === */
.cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;z-index:200;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.12);max-width:640px;margin:0 auto}
.cookie-banner__inner{padding:20px 24px;display:flex;gap:20px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cookie-banner p{font-size:.88rem;color:var(--muted);margin:0;flex:1;min-width:240px;line-height:1.5}
.cookie-banner a{text-decoration:underline;color:var(--fg)}
@media (max-width:520px){.cookie-banner{left:12px;right:12px;bottom:12px}.cookie-banner__inner{padding:16px}}

/* === SECTION INTRO === */
.section__intro{font-size:1.05rem;color:var(--muted);margin-top:18px;line-height:1.65;max-width:600px}
.section--dark .section__intro{color:#bbb}

/* === SERVICE LIST === */
.service__list{margin-top:18px;padding-top:18px;border-top:1px solid rgba(0,0,0,.08);display:flex;flex-direction:column;gap:6px}
.service--dark .service__list{border-top-color:rgba(255,255,255,.1)}
.service__list li{font-size:.88rem;color:var(--muted);padding-left:16px;position:relative}
.service--dark .service__list li{color:#999}
.service__list li::before{content:"→";position:absolute;left:0;color:#888}

/* === ABOUT VALUES === */
.about__values{display:grid;grid-template-columns:1fr;gap:14px;margin-top:32px;padding-top:28px;border-top:1px solid #2a2a2a}
.about__values div{display:flex;align-items:baseline;gap:14px}
.about__values strong{font-family:var(--serif);font-size:1.05rem;font-weight:500;color:#fff;min-width:110px}
.about__values span{font-size:.9rem;color:#999}

/* === FAQ === */
.faq{display:flex;flex-direction:column;gap:12px;max-width:820px}
.faq__item{border:1px solid var(--line);border-radius:14px;background:#fff;transition:border-color .2s}
.faq__item[open]{border-color:var(--fg)}
.faq__item summary{padding:22px 28px;cursor:pointer;font-weight:500;font-size:1rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--serif);font-size:1.6rem;font-weight:300;color:#888;transition:transform .3s}
.faq__item[open] summary::after{content:"−"}
.faq__item p{padding:0 28px 24px;color:var(--muted);font-size:.95rem;line-height:1.7;margin:0}
.faq__item p strong{color:var(--fg)}

@media (max-width:520px){
  .faq__item summary{padding:18px 20px;font-size:.95rem}
  .faq__item p{padding:0 20px 20px}
}
