/*
Theme Name: FAYCE
Theme URI: https://fayce.ch
Author: FAYCE
Description: Custom premium theme for FAYCE Portraitfotografie Bern
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: fayce
*/

/* === RESET & BASE === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

:root{
  --black:#0a0a0a;
  --near-black:#111110;
  --white:#f8f7f5;
  --warm-white:#f2f0ec;
  --stone:#c8c2b8;
  --stone-light:#e8e4de;
  --stone-dark:#8a8378;
  --charcoal:#2c2a27;
  --accent:#b8a089;
  --accent-deep:#96806a;
  --accent-glow:rgba(184,160,137,.06);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',sans-serif;
}

body{
  background:var(--black);
  color:var(--white);
  font-family:var(--sans);
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-size:16px;
  line-height:1.6;
}

a{color:inherit;text-decoration:none;transition:color .3s}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4,h5,h6{font-weight:300}

.container{
  max-width:1400px;
  margin:0 auto;
  padding:0 clamp(24px,5vw,60px);
}

/* === NAVIGATION === */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:24px clamp(24px,5vw,60px);
  transition:background .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}

.site-nav.scrolled{
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:16px clamp(24px,5vw,60px);
  border-bottom-color:rgba(200,194,184,.06);
}

.nav-logo{
  font-family:var(--sans);font-weight:300;
  font-size:18px;letter-spacing:6px;text-transform:uppercase;
}
.nav-logo .y{color:var(--accent)}

.nav-menu{display:flex;gap:32px;list-style:none}
.nav-menu a{
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--stone);transition:color .3s;
}
.nav-menu a:hover{color:var(--white)}

.nav-cta{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  padding:10px 24px;border:1px solid rgba(184,160,137,.3);
  color:var(--accent);transition:all .3s;
}
.nav-cta:hover{background:var(--accent);color:var(--black);border-color:var(--accent)}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:1px;background:var(--white);margin:6px 0;transition:all .3s}

/* === HERO === */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
  padding:0 clamp(24px,8vw,140px);
  overflow:hidden;
}

.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 70% 50%,rgba(184,160,137,.06) 0%,transparent 50%),
             radial-gradient(ellipse at 30% 80%,rgba(184,160,137,.03) 0%,transparent 40%);
  pointer-events:none;
}

.hero-image{
  position:absolute;top:0;right:0;
  width:55%;height:100%;
  overflow:hidden;
}

.hero-image img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
}

.hero-image-placeholder{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--charcoal) 0%,var(--near-black) 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-style:italic;font-size:16px;color:var(--stone-dark);letter-spacing:2px;
}

.hero-content{position:relative;z-index:2;max-width:520px}

.hero-tag{
  font-size:11px;letter-spacing:4px;text-transform:uppercase;
  color:var(--stone-dark);margin-bottom:24px;
}

.hero-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(42px,6vw,72px);line-height:1.1;
  margin-bottom:24px;
}
.hero-title em{font-style:italic;color:var(--accent)}

.hero-desc{
  font-size:15px;line-height:1.8;color:var(--stone);
  margin-bottom:40px;max-width:400px;
}

.btn-primary{
  display:inline-block;font-size:11px;letter-spacing:3px;text-transform:uppercase;
  padding:16px 40px;border:1px solid var(--accent);color:var(--accent);transition:all .4s;
}
.btn-primary:hover{background:var(--accent);color:var(--black)}

.btn-solid{
  display:inline-block;font-size:12px;letter-spacing:3px;text-transform:uppercase;
  padding:18px 48px;background:var(--accent);color:var(--black);font-weight:400;transition:all .4s;
}
.btn-solid:hover{background:var(--white)}

.hero-scroll{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.hero-scroll span{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--stone-dark)}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollPulse 2s ease-in-out infinite}

/* === SECTION COMMON === */
.section-tag{
  font-size:10px;letter-spacing:4px;text-transform:uppercase;
  color:var(--stone-dark);margin-bottom:16px;
}

.section-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,4vw,48px);line-height:1.15;
}
.section-title em{font-style:italic;color:var(--accent)}

.section-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:48px;
}

.section-link{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--stone-dark);border-bottom:1px solid rgba(184,160,137,.2);
  padding-bottom:4px;transition:color .3s,border-color .3s;white-space:nowrap;
}
.section-link:hover{color:var(--accent);border-color:var(--accent)}

/* === PORTFOLIO GRID === */
.portfolio-section{padding:clamp(80px,12vw,160px) clamp(24px,5vw,60px)}

.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:3px;
}

.portfolio-card{
  aspect-ratio:3/4;background:var(--charcoal);
  position:relative;overflow:hidden;cursor:pointer;
}

.portfolio-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s cubic-bezier(.16,1,.3,1);
}

.portfolio-card:hover img{transform:scale(1.05)}

.portfolio-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.8) 0%,transparent 50%);
  z-index:1;opacity:0;transition:opacity .4s;
}
.portfolio-card:hover::before{opacity:1}

.portfolio-card-inner{
  position:absolute;bottom:0;left:0;right:0;padding:24px;
  z-index:2;transform:translateY(10px);opacity:0;transition:all .4s;
}
.portfolio-card:hover .portfolio-card-inner{transform:translateY(0);opacity:1}

.portfolio-card-title{font-family:var(--serif);font-weight:300;font-size:22px;margin-bottom:4px}
.portfolio-card-sub{font-size:11px;letter-spacing:1px;color:var(--stone)}

.portfolio-card-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-style:italic;font-size:14px;color:var(--stone-dark);
  background:var(--charcoal);transition:transform .6s cubic-bezier(.16,1,.3,1);
}
.portfolio-card:hover .portfolio-card-placeholder{transform:scale(1.05)}

/* === ABOUT === */
.about-section{
  padding:clamp(80px,12vw,160px) clamp(24px,5vw,60px);
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,100px);align-items:center;
}

.about-image{
  aspect-ratio:3/4;background:var(--charcoal);overflow:hidden;
}
.about-image img{width:100%;height:100%;object-fit:cover}

.about-text{
  font-size:15px;line-height:1.85;color:var(--stone);margin:20px 0 32px;
}
.about-text strong{color:var(--white);font-weight:400}

.about-link{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--accent);border-bottom:1px solid var(--accent);
  padding-bottom:4px;transition:opacity .3s;
}
.about-link:hover{opacity:.7}

/* === TESTIMONIALS === */
.testimonials{padding:clamp(80px,12vw,160px) clamp(24px,5vw,60px)}

.testimonial-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;margin-top:48px;
}

.testimonial-card{
  background:var(--near-black);padding:40px 32px;
  text-align:left;transition:background .4s;
}
.testimonial-card:hover{background:var(--accent-glow)}

.testimonial-quote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:17px;line-height:1.65;color:var(--stone-light);margin-bottom:24px;
}

.testimonial-stars{color:var(--accent);font-size:12px;letter-spacing:2px;margin-bottom:16px}

.testimonial-name{font-size:12px;font-weight:400;color:var(--white);letter-spacing:1px}
.testimonial-role{font-size:11px;color:var(--stone-dark);margin-top:2px}

/* === CTA === */
.cta-section{
  padding:clamp(100px,14vw,200px) clamp(24px,5vw,60px);
  text-align:center;position:relative;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(184,160,137,.05) 0%,transparent 60%);
  pointer-events:none;
}

.cta-title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(36px,5vw,64px);line-height:1.15;
  margin-bottom:20px;position:relative;
}
.cta-title em{font-style:italic;color:var(--accent)}

.cta-desc{font-size:15px;color:var(--stone);margin-bottom:40px;position:relative}

/* === LEISTUNGEN / PREISE === */
.leistungen-section{padding:clamp(80px,12vw,160px) clamp(24px,5vw,60px)}

.pakete-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;margin-top:48px;
}

.paket-card{
  background:var(--near-black);padding:48px 36px;
  display:flex;flex-direction:column;
  transition:background .4s;position:relative;
}
.paket-card:hover{background:var(--accent-glow)}

.paket-card.featured{border-top:2px solid var(--accent)}
.paket-card.featured .paket-badge{display:block}

.paket-badge{
  display:none;position:absolute;top:16px;right:20px;
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:var(--accent);
}

.paket-name{
  font-family:var(--serif);font-weight:300;font-size:28px;margin-bottom:8px;
}

.paket-price{
  font-size:32px;font-weight:400;color:var(--white);margin-bottom:4px;
}

.paket-price-sub{font-size:12px;color:var(--stone-dark);margin-bottom:24px}

.paket-divider{width:40px;height:1px;background:rgba(200,194,184,.15);margin:24px 0}

.paket-features{list-style:none;flex:1}
.paket-features li{
  font-size:13px;color:var(--stone);padding:8px 0;
  border-bottom:1px solid rgba(200,194,184,.04);
}
.paket-features li:last-child{border-bottom:none}

.paket-cta{
  margin-top:32px;display:inline-block;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  padding:14px 32px;border:1px solid rgba(184,160,137,.2);
  color:var(--accent);text-align:center;transition:all .3s;
}
.paket-cta:hover{background:var(--accent);color:var(--black);border-color:var(--accent)}

/* === FAQ === */
.faq-section{padding:clamp(80px,12vw,160px) clamp(24px,5vw,60px)}

.faq-list{max-width:800px;margin-top:48px}

.faq-item{border-bottom:1px solid rgba(200,194,184,.08)}

.faq-question{
  padding:24px 0;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  font-size:16px;font-weight:400;color:var(--white);
  transition:color .3s;
}
.faq-question:hover{color:var(--accent)}

.faq-toggle{
  font-size:18px;color:var(--stone-dark);
  transition:transform .3s,color .3s;
}
.faq-item.open .faq-toggle{transform:rotate(45deg);color:var(--accent)}

.faq-answer{
  display:none;padding:0 0 24px;
  font-size:14px;line-height:1.8;color:var(--stone);max-width:640px;
}
.faq-item.open .faq-answer{display:block}

/* === KONTAKT === */
.kontakt-section{
  padding:clamp(80px,12vw,160px) clamp(24px,5vw,60px);
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,100px);
}

.kontakt-info{display:flex;flex-direction:column;justify-content:center}

.kontakt-item{margin-bottom:32px}
.kontakt-label{
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--stone-dark);margin-bottom:8px;
}
.kontakt-value{font-size:16px;color:var(--stone-light)}
.kontakt-value a:hover{color:var(--accent)}

.kontakt-form{}
.kontakt-form .form-group{margin-bottom:20px}
.kontakt-form label{
  display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--stone-dark);margin-bottom:8px;
}
.kontakt-form input,
.kontakt-form select,
.kontakt-form textarea{
  width:100%;padding:14px 16px;
  background:var(--near-black);border:1px solid rgba(200,194,184,.1);
  color:var(--white);font-family:var(--sans);font-weight:300;font-size:14px;
  transition:border-color .3s;
}
.kontakt-form input:focus,
.kontakt-form select:focus,
.kontakt-form textarea:focus{
  outline:none;border-color:var(--accent);
}
.kontakt-form textarea{resize:vertical;min-height:120px}
.kontakt-form select{cursor:pointer;appearance:none}

/* === JOURNAL / BLOG === */
.journal-section{padding:clamp(80px,12vw,160px) clamp(24px,5vw,60px)}

.journal-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;margin-top:48px;
}

.journal-card{cursor:pointer;transition:transform .3s}
.journal-card:hover{transform:translateY(-4px)}

.journal-card-image{
  aspect-ratio:16/10;background:var(--charcoal);
  overflow:hidden;margin-bottom:16px;
}
.journal-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.journal-card:hover .journal-card-image img{transform:scale(1.04)}

.journal-card-date{font-size:11px;color:var(--stone-dark);letter-spacing:1px;margin-bottom:8px}
.journal-card-title{font-family:var(--serif);font-weight:400;font-size:20px;line-height:1.35;margin-bottom:8px}
.journal-card-excerpt{font-size:13px;color:var(--stone);line-height:1.7}

/* === SINGLE POST === */
.single-post{padding:clamp(120px,14vw,180px) 0 clamp(80px,10vw,120px);max-width:780px;margin:0 auto}
.single-post .post-meta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--stone-dark);margin-bottom:16px}
.single-post h1{font-family:var(--serif);font-weight:300;font-size:clamp(32px,4vw,52px);line-height:1.15;margin-bottom:32px}
.single-post .post-content{font-size:16px;line-height:1.9;color:var(--stone)}
.single-post .post-content p{margin-bottom:24px}
.single-post .post-content h2{font-family:var(--serif);font-weight:400;font-size:28px;margin:48px 0 16px;color:var(--white)}
.single-post .post-content h3{font-weight:400;font-size:18px;margin:32px 0 12px;color:var(--white)}
.single-post .post-content img{margin:32px 0;width:100%}
.single-post .post-content strong{color:var(--white);font-weight:400}
.single-post .post-content a{color:var(--accent);border-bottom:1px solid rgba(184,160,137,.3)}
.single-post .post-content a:hover{border-color:var(--accent)}

/* === FOOTER === */
.site-footer{
  border-top:1px solid rgba(200,194,184,.08);
  padding:60px clamp(24px,5vw,60px);
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;
}

.footer-brand .nav-logo{font-size:20px;letter-spacing:8px;margin-bottom:16px}
.footer-tagline{font-family:var(--serif);font-style:italic;font-weight:300;font-size:14px;color:var(--stone-dark)}

.footer-col h4{
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--stone-dark);font-weight:400;margin-bottom:20px;
}
.footer-col a{
  display:block;font-size:13px;color:var(--stone);
  margin-bottom:12px;transition:color .3s;
}
.footer-col a:hover{color:var(--white)}

.footer-bottom{
  grid-column:1/-1;display:flex;justify-content:space-between;
  padding-top:32px;border-top:1px solid rgba(200,194,184,.06);
  font-size:11px;color:var(--stone-dark);
}
.footer-bottom a{color:var(--stone-dark)}
.footer-bottom a:hover{color:var(--stone)}

/* === ANIMATIONS === */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:.8}}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

.fade-in{opacity:0;animation:fadeUp .8s cubic-bezier(.16,1,.3,1) forwards}
.fade-in-1{animation-delay:.3s}
.fade-in-2{animation-delay:.5s}
.fade-in-3{animation-delay:.7s}
.fade-in-4{animation-delay:.9s}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .hero-image{width:45%}
  .portfolio-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:768px){
  .nav-menu{
    display:none;position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(10,10,10,.98);flex-direction:column;
    justify-content:center;align-items:center;gap:24px;
  }
  .nav-menu.open{display:flex}
  .nav-menu a{font-size:18px;letter-spacing:4px}
  .nav-toggle{display:block}
  .nav-cta-desktop{display:none}

  .hero-image{display:none}
  .hero-content{max-width:100%}

  .portfolio-grid{grid-template-columns:1fr 1fr}
  .about-section{grid-template-columns:1fr}
  .testimonial-grid{grid-template-columns:1fr}
  .pakete-grid{grid-template-columns:1fr}
  .journal-grid{grid-template-columns:1fr}
  .kontakt-section{grid-template-columns:1fr}
  .site-footer{grid-template-columns:1fr}
}

/* === WORDPRESS SPECIFIC === */
.alignleft{float:left;margin:0 24px 24px 0}
.alignright{float:right;margin:0 0 24px 24px}
.aligncenter{display:block;margin:24px auto}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:12px;color:var(--stone-dark);margin-top:8px}
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute;height:1px;width:1px;overflow:hidden}
</style>
