/*
Theme Name: Sophie Schillen
Description: Portfolio für Sophie Schillen – Zeitgenössische abstrakte Kunst
Version: 4.0.0
License: GNU General Public License v2 or later
Text Domain: sophie-schillen
*/

:root {
  --bg: #F5F3F0; --dark: #111010; --muted: #7A7874;
  --accent: #BF1F5E; --white: #FFFFFF; --off: #EDEAE5;
  --font-d: 'Cormorant Garamond', Georgia, serif;
  --font-b: 'Inter', Helvetica, Arial, sans-serif;
  --ease: cubic-bezier(0.22,1,0.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--dark);font-family:var(--font-b);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.6rem 4rem;display:flex;align-items:center;justify-content:space-between;transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s ease;}
.site-header.scrolled{background:rgba(17,16,16,.92);backdrop-filter:blur(14px);padding:1rem 4rem;box-shadow:0 1px 0 rgba(255,255,255,.06);}
.site-logo{font-family:var(--font-d);font-size:1.05rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--white);transition:opacity .4s;}
.site-logo:hover{opacity:.75;}
.site-nav{display:flex;align-items:center;gap:2.6rem;}
.ss-nav-item{position:relative;font-size:.68rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7);padding:.4rem 0;transition:color .4s var(--ease);}
.ss-nav-item span{position:relative;display:inline-block;}
.ss-nav-item span::after{content:'';position:absolute;left:0;bottom:-6px;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease);}
.ss-nav-item:hover,.ss-nav-item.is-active{color:var(--white);}
.ss-nav-item:hover span::after,.ss-nav-item.is-active span::after{transform:scaleX(1);transform-origin:left;}
.nav-lang{font-size:.66rem;letter-spacing:.12em;color:rgba(255,255,255,.4);padding-left:1.6rem;border-left:1px solid rgba(255,255,255,.15);}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.3rem;flex-direction:column;gap:5px;z-index:101;}
.menu-toggle span{display:block;width:24px;height:1.5px;background:var(--white);transition:transform .4s var(--ease),opacity .3s ease;}

/* HERO */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:flex-end;}
.hero__bg{position:absolute;inset:0;background:var(--dark);}
.hero__bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;opacity:.72;}
.hero__gradient{position:absolute;inset:0;background:linear-gradient(to right,rgba(17,16,16,.88) 0%,rgba(17,16,16,.3) 60%,rgba(17,16,16,.05) 100%);}
.hero__content{position:relative;z-index:2;padding:0 4rem 7rem;max-width:580px;}
.hero__eyebrow{font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:1.2rem;}
.hero__title{font-family:var(--font-d);font-size:clamp(3rem,7vw,6.5rem);font-weight:300;color:var(--white);line-height:.95;margin-bottom:1.5rem;}
.hero__divider{width:36px;height:1px;background:var(--accent);margin-bottom:1.5rem;}
.hero__text{font-size:1rem;line-height:1.7;color:rgba(255,255,255,.7);margin-bottom:2.5rem;max-width:380px;}
.btn-outline{display:inline-flex;align-items:center;gap:.9rem;font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--white);border:1px solid rgba(255,255,255,.5);padding:.85rem 1.8rem;transition:border-color .35s,background .35s;}
.btn-outline:hover{border-color:var(--white);background:rgba(255,255,255,.1);}
.btn-outline svg{width:16px;height:16px;flex-shrink:0;}

/* SECTIONS */
.section{padding:7rem 4rem;}
.section--off{background:var(--off);}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:4rem;padding-bottom:1.2rem;border-bottom:1px solid rgba(0,0,0,.1);}
.section-title{font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);}
.section-link{font-size:.68rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.5rem;transition:color .3s;}
.section-link:hover{color:var(--accent);}
.section-link svg{width:14px;height:14px;}

/* WORKS GRID */
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;}
.work-card a{display:block;}
.work-card__img{overflow:hidden;aspect-ratio:4/5;background:#D8D4CE;margin-bottom:1rem;}
.work-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.work-card:hover .work-card__img img{transform:scale(1.05);}
.work-card__title{font-family:var(--font-d);font-size:1.05rem;font-weight:400;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.3rem;color:var(--dark);}
.work-card__meta{font-size:.75rem;color:var(--muted);line-height:1.5;}

/* SINGLE WERK */
.werk-wrap{max-width:860px;margin:0 auto;padding:calc(6rem + 80px) 4rem 7rem;}
.werk-eyebrow{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;}
.werk-title{font-family:var(--font-d);font-size:clamp(2rem,5vw,4rem);font-weight:300;text-transform:uppercase;letter-spacing:.04em;line-height:1.05;margin-bottom:1rem;}
.werk-divider{width:36px;height:1px;background:var(--accent);margin-bottom:1.5rem;}
.werk-meta{font-size:.88rem;color:var(--muted);margin-bottom:2.5rem;}
.werk-image{width:100%;margin-bottom:2rem;}
.werk-image img{width:100%;height:auto;display:block;}
.werk-desc{font-size:.97rem;line-height:1.85;color:var(--muted);margin-bottom:2rem;}
.werk-desc p{margin-bottom:1rem;}
.werk-desc img{width:100%;height:auto;margin-bottom:1rem;}
.werk-desc figure{margin:0 0 1rem;}
.werk-desc figure img{width:100%;}
.werk-back{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:2rem;border-bottom:1px solid rgba(0,0,0,.15);padding-bottom:.1rem;transition:color .3s,border-color .3s;}
.werk-back:hover{color:var(--accent);border-color:var(--accent);}

/* PAGE */
.page-wrap{max-width:760px;margin:0 auto;padding:calc(5rem + 80px) 4rem 7rem;}
.page-eyebrow{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;}
.page-title{font-family:var(--font-d);font-size:clamp(2rem,5vw,4rem);font-weight:300;text-transform:uppercase;letter-spacing:.04em;line-height:1.05;margin-bottom:1.5rem;}
.page-divider{width:36px;height:1px;background:var(--accent);margin-bottom:2.5rem;}
.page-thumb{width:100%;overflow:hidden;margin-bottom:3rem;background:#D8D4CE;}
.page-thumb img{width:100%;height:auto;display:block;}
.page-content p{font-size:.97rem;line-height:1.85;color:var(--muted);margin-bottom:1.5rem;}
.page-content p:last-child{font-style:italic;color:var(--dark);margin-bottom:0;}
.page-content img{width:100%;height:auto;margin-bottom:1.5rem;display:block;}
.page-content figure{margin:0 0 1.5rem;}
.page-content figure img{width:100%;}

/* STATEMENT */
.statement-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.statement-text h2{font-family:var(--font-d);font-size:clamp(2rem,4vw,3.5rem);font-weight:300;text-transform:uppercase;letter-spacing:.04em;line-height:1.05;margin-bottom:1.5rem;}
.statement-divider{width:36px;height:1px;background:var(--accent);margin-bottom:1.5rem;}
.statement-text p{font-size:.95rem;line-height:1.8;color:var(--muted);margin-bottom:2rem;max-width:440px;}
.link-arrow{font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--dark);display:inline-flex;align-items:center;gap:.8rem;border-bottom:1px solid var(--dark);padding-bottom:.1rem;transition:color .3s,border-color .3s,gap .3s;}
.link-arrow:hover{color:var(--accent);border-color:var(--accent);gap:1.2rem;}
.link-arrow svg{width:14px;height:14px;}
.statement-image{overflow:hidden;aspect-ratio:3/4;background:#D8D4CE;}
.statement-image img{width:100%;height:100%;object-fit:cover;object-position:center top;}

/* CONTACT */
.contact-form{display:flex;flex-direction:column;gap:1.4rem;margin-top:2.5rem;}
.cf-label{display:block;font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;}
.cf-input,.cf-textarea{width:100%;padding:.85rem 1rem;border:1px solid rgba(0,0,0,.18);background:transparent;font-family:var(--font-b);font-size:.95rem;outline:none;transition:border-color .25s;resize:vertical;}
.cf-input:focus,.cf-textarea:focus{border-color:var(--accent);}
.cf-btn{display:inline-flex;align-items:center;gap:.9rem;font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--dark);border:1px solid var(--dark);background:transparent;padding:.85rem 1.8rem;cursor:pointer;transition:background .3s,color .3s;}
.cf-btn:hover{background:var(--dark);color:var(--white);}
.cf-btn svg{width:16px;height:16px;}

/* FOOTER */
.site-footer{background:var(--dark);color:rgba(255,255,255,.45);padding:2rem 4rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.footer-copy{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;}
.footer-links{display:flex;gap:2rem;}
.footer-links a{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);transition:color .3s;}
.footer-links a:hover{color:var(--white);}
.footer-social{display:flex;align-items:center;gap:.6rem;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;}
.footer-social a{color:rgba(255,255,255,.45);transition:color .3s;display:flex;}
.footer-social a:hover{color:var(--accent);}

/* RESPONSIVE */
@media(max-width:1100px){.works-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:860px){
  .site-header,.site-header.scrolled{padding:1.2rem 1.5rem;}
  .site-nav{flex-direction:column;position:fixed;inset:0;background:rgba(13,12,12,.97);backdrop-filter:blur(18px);z-index:99;align-items:center;justify-content:center;gap:2.2rem;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .45s var(--ease),visibility 0s linear .45s;}
  .site-nav.open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .45s var(--ease),visibility 0s linear 0s;}
  .ss-nav-item{font-size:1.3rem;letter-spacing:.1em;opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease),transform .5s var(--ease);}
  .site-nav.open .ss-nav-item{opacity:1;transform:translateY(0);}
  .site-nav.open .ss-nav-item:nth-child(1){transition-delay:.08s;}
  .site-nav.open .ss-nav-item:nth-child(2){transition-delay:.14s;}
  .site-nav.open .ss-nav-item:nth-child(3){transition-delay:.20s;}
  .site-nav.open .ss-nav-item:nth-child(4){transition-delay:.26s;}
  .site-nav .nav-lang{opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease) .32s,transform .5s var(--ease) .32s;border-left:none;padding-left:0;}
  .site-nav.open .nav-lang{opacity:1;transform:translateY(0);}
  .menu-toggle{display:flex;}
  .section{padding:4rem 1.5rem;}
  .hero__content{padding:0 1.5rem 5rem;}
  .statement-grid{grid-template-columns:1fr;}
  .statement-image{order:-1;aspect-ratio:4/3;}
  .works-grid{grid-template-columns:repeat(2,1fr);gap:1rem;}
  .werk-wrap{padding:calc(3rem + 80px) 1.5rem 4rem;}
  .page-wrap{padding:calc(3rem + 80px) 1.5rem 4rem;}
  .site-footer{flex-direction:column;text-align:center;padding:2rem 1.5rem;}
}
@media(max-width:480px){
  .works-grid{grid-template-columns:1fr;}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;}}
