/* ===========================================================
   Pracownia Beauty, atelier warmth
   cream + terracotta + olive
   =========================================================== */

:root{
  --canvas:#f1e8dc;
  --canvas-deep:#e9dccb;
  --ink:#2c2218;
  --primary:#b15a3c;
  --primary-deep:#9a4a2f;
  --secondary:#e6d6c2;
  --muted:#7b6c58;
  --accent:#6f6a3a;        /* olive, locked, sparing */
  --paper:#faf4ea;
  --line:rgba(44,34,24,.14);
  --shadow:30px 40px 80px -50px rgba(44,34,24,.55);
  --shadow-soft:18px 24px 50px -36px rgba(44,34,24,.45);
  --r-lg:30px;
  --r-md:20px;
  --r-sm:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  font-family:"Karla",system-ui,sans-serif;
  color:var(--ink);
  background:var(--canvas);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}

/* warm grain + ambient wash over whole page */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(60% 50% at 12% 8%, rgba(177,90,60,.10), transparent 60%),
    radial-gradient(55% 45% at 90% 22%, rgba(111,106,58,.08), transparent 62%),
    radial-gradient(70% 60% at 80% 96%, rgba(177,90,60,.07), transparent 60%);
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

main,header,footer{position:relative;z-index:1}

h1,h2,h3,h4{
  font-family:"Newsreader",Georgia,serif;
  font-weight:500;
  line-height:1.06;
  letter-spacing:-.012em;
  color:var(--ink);
}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.wrap{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:28px;
}

.eyebrow{
  font-family:"Karla",sans-serif;
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--primary);
}

.italic{font-style:italic;font-family:"Newsreader",serif}
.olive{color:var(--accent)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.6em;
  font-family:"Karla",sans-serif;
  font-weight:600;
  font-size:.96rem;
  letter-spacing:.01em;
  padding:.92em 1.7em;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
  will-change:transform;
}
.btn-primary{
  background:var(--primary);
  color:#fbf0e6;
  box-shadow:0 16px 34px -18px rgba(177,90,60,.8);
}
.btn-primary:hover{background:var(--primary-deep);transform:translateY(-2px)}
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--line);
}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translate(3px,-3px)}

/* ===========================================================
   HEADER
   =========================================================== */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px clamp(20px,5vw,48px);
  background:rgba(241,232,220,.72);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease), background .4s var(--ease);
}
.site-header.scrolled{
  border-bottom-color:var(--line);
  background:rgba(241,232,220,.88);
}
.brand{
  display:flex;
  align-items:baseline;
  gap:.5em;
  font-family:"Newsreader",serif;
  font-size:1.32rem;
  font-weight:500;
  letter-spacing:-.01em;
}
.brand .mark{
  font-style:italic;
  color:var(--primary);
}
.brand .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);
  display:inline-block;
  margin-left:.15em;
  transform:translateY(-2px);
}
.nav{
  display:flex;
  align-items:center;
  gap:clamp(18px,2.4vw,34px);
}
.nav-links{
  display:flex;
  gap:clamp(16px,2vw,30px);
}
.nav-links a{
  font-size:.92rem;
  font-weight:500;
  color:var(--ink);
  position:relative;
  padding-block:4px;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;bottom:0;
  width:0;height:1.5px;
  background:var(--primary);
  transition:width .35s var(--ease);
}
.nav-links a:hover::after{width:100%}

.lang-toggle{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--line);
  border-radius:999px;
  overflow:hidden;
  font-family:"Karla",sans-serif;
  font-size:.78rem;
  font-weight:600;
}
.lang-toggle button{
  background:transparent;
  border:none;
  cursor:pointer;
  padding:.42em .82em;
  color:var(--muted);
  letter-spacing:.04em;
  transition:background .3s var(--ease), color .3s var(--ease);
}
.lang-toggle button.active{
  background:var(--ink);
  color:var(--paper);
}
.menu-btn{display:none}

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(28px,4vw,64px);
  align-items:center;
  max-width:var(--maxw);
  margin-inline:auto;
  padding:clamp(40px,7vw,90px) 28px clamp(50px,7vw,96px);
}
.hero-copy{max-width:560px}
.hero h1{
  font-size:clamp(2.7rem,6vw,4.6rem);
  font-weight:500;
  margin:.32em 0 .5em;
}
.hero h1 em{
  font-style:italic;
  color:var(--primary);
  font-weight:400;
}
.hero-lead{
  font-size:1.14rem;
  color:var(--muted);
  max-width:46ch;
  margin-bottom:1.8em;
}
.hero-cta{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
}
.hero-rating{
  display:flex;
  align-items:center;
  gap:.7em;
  margin-top:1.9em;
  font-size:.92rem;
  color:var(--muted);
}
.hero-rating .stars{
  color:var(--primary);
  letter-spacing:.14em;
  font-size:.95rem;
}
.hero-rating b{color:var(--ink);font-weight:700}

.hero-media{
  position:relative;
}
.hero-media .frame{
  position:relative;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  aspect-ratio:720/1000;
}
.hero-media .frame img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 38%;
}
.hero-media .tag{
  position:absolute;
  left:-18px;
  bottom:34px;
  background:var(--paper);
  border-radius:var(--r-md);
  padding:14px 20px;
  box-shadow:var(--shadow-soft);
  border:1px solid var(--line);
  max-width:220px;
}
.hero-media .tag .t-label{
  font-family:"Karla",sans-serif;
  font-size:.68rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:600;
}
.hero-media .tag .t-text{
  font-family:"Newsreader",serif;
  font-style:italic;
  font-size:1.18rem;
  line-height:1.2;
  margin-top:.2em;
}

/* ===========================================================
   marquee strip
   =========================================================== */
.strip{
  border-block:1px solid var(--line);
  background:linear-gradient(var(--canvas-deep),var(--canvas-deep));
  overflow:hidden;
  padding-block:16px;
}
.strip-track{
  display:flex;
  gap:54px;
  width:max-content;
  animation:slide 32s linear infinite;
}
.strip-track span{
  font-family:"Newsreader",serif;
  font-size:1.05rem;
  color:var(--muted);
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  gap:54px;
}
.strip-track span::after{
  content:"·";
  color:var(--primary);
  font-size:1.4rem;
}
@keyframes slide{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.strip-track{animation:none}}

/* ===========================================================
   SECTION shell
   =========================================================== */
section{padding-block:clamp(56px,8vw,110px)}
.sec-head{
  max-width:680px;
  margin-bottom:clamp(32px,4vw,56px);
}
.sec-head h2{
  font-size:clamp(2rem,4.4vw,3.2rem);
  margin:.3em 0 .35em;
}
.sec-head h2 em{font-style:italic;color:var(--primary);font-weight:400}
.sec-head p{color:var(--muted);font-size:1.08rem;max-width:54ch}

/* ---------- about / story ---------- */
.story{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(28px,4vw,64px);
  align-items:center;
}
.story-media{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;
  gap:14px;
}
.story-media figure{
  border-radius:var(--r-md);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  margin:0;
}
.story-media figure img{width:100%;height:100%;object-fit:cover}
.story-media .tall{grid-row:span 2;aspect-ratio:4/5}
.story-media .wide{aspect-ratio:4/3}
.story-copy h2{
  font-size:clamp(1.9rem,4vw,2.9rem);
  margin:.3em 0 .55em;
}
.story-copy h2 em{font-style:italic;color:var(--primary);font-weight:400}
.story-copy p{color:var(--muted);margin-bottom:1.1em;max-width:46ch}
.story-copy p strong{color:var(--ink);font-weight:600}
.story-stats{
  display:flex;
  gap:34px;
  margin-top:1.7em;
  flex-wrap:wrap;
}
.story-stats .stat .num{
  font-family:"Newsreader",serif;
  font-size:2rem;
  color:var(--ink);
  line-height:1;
}
.story-stats .stat .lab{
  font-size:.82rem;
  color:var(--muted);
  margin-top:.4em;
}

/* ---------- gallery ---------- */
.gallery-sec{background:linear-gradient(180deg,transparent,rgba(230,214,194,.35) 30%,transparent)}
.gallery{
  columns:3;
  column-gap:18px;
}
.gallery figure{
  margin:0 0 18px;
  break-inside:avoid;
  border-radius:var(--r-md);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  position:relative;
  background:var(--secondary);
}
.gallery figure img{
  width:100%;
  height:auto;
  display:block;
  transition:transform 1s var(--ease);
}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figure figcaption{
  position:absolute;
  left:0;right:0;bottom:0;
  padding:18px 16px 14px;
  font-family:"Newsreader",serif;
  font-style:italic;
  font-size:1.02rem;
  color:#fbf0e6;
  background:linear-gradient(transparent,rgba(44,34,24,.7));
  opacity:0;
  transform:translateY(8px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.gallery figure:hover figcaption{opacity:1;transform:translateY(0)}

/* ---------- services ---------- */
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.svc-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:30px 28px 28px;
  box-shadow:var(--shadow-soft);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
  display:flex;
  flex-direction:column;
}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.svc-card .num{
  font-family:"Newsreader",serif;
  font-style:italic;
  color:var(--accent);
  font-size:1.05rem;
  margin-bottom:.7em;
}
.svc-card h3{
  font-size:1.5rem;
  margin-bottom:.5em;
}
.svc-card p{
  color:var(--muted);
  font-size:.97rem;
  margin-bottom:1.2em;
}
.svc-card ul{list-style:none;margin-top:auto}
.svc-card li{
  font-size:.93rem;
  color:var(--ink);
  padding:.5em 0;
  border-top:1px solid var(--line);
  display:flex;
  align-items:center;
  gap:.7em;
}
.svc-card li::before{
  content:"";
  width:5px;height:5px;border-radius:50%;
  background:var(--primary);
  flex:none;
}

/* ---------- approach band ---------- */
.approach{
  background:var(--ink);
  color:var(--canvas);
  border-radius:clamp(24px,3vw,44px);
  margin-inline:clamp(0px,2vw,0px);
  position:relative;
  overflow:hidden;
}
.approach .wrap{padding-block:clamp(48px,7vw,92px)}
.approach::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(50% 60% at 85% 10%,rgba(177,90,60,.32),transparent 60%),
    radial-gradient(45% 55% at 8% 95%,rgba(111,106,58,.28),transparent 60%);
  pointer-events:none;
}
.approach .a-head{position:relative;max-width:640px;margin-bottom:clamp(34px,5vw,58px)}
.approach .a-head .eyebrow{color:#e6b9a4}
.approach .a-head h2{
  color:var(--canvas);
  font-size:clamp(2rem,4.4vw,3.1rem);
  margin-top:.3em;
}
.approach .a-head h2 em{font-style:italic;color:#e6b9a4;font-weight:400}
.approach-steps{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}
.approach-steps .step{
  border-top:1px solid rgba(241,232,220,.22);
  padding-top:22px;
}
.approach-steps .step .s-num{
  font-family:"Newsreader",serif;
  font-style:italic;
  font-size:1.4rem;
  color:#e6b9a4;
  margin-bottom:.5em;
}
.approach-steps .step h3{
  color:var(--canvas);
  font-size:1.4rem;
  margin-bottom:.45em;
}
.approach-steps .step p{
  color:rgba(241,232,220,.74);
  font-size:.96rem;
}

/* ---------- contact ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:clamp(28px,4vw,56px);
  align-items:start;
}
.contact-info .line{
  display:flex;
  flex-direction:column;
  gap:.25em;
  padding:18px 0;
  border-bottom:1px solid var(--line);
}
.contact-info .line:first-of-type{border-top:1px solid var(--line)}
.contact-info .line .k{
  font-size:.72rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:600;
}
.contact-info .line .v{
  font-family:"Newsreader",serif;
  font-size:1.22rem;
  color:var(--ink);
}
.contact-info .line a.v:hover{color:var(--primary)}
.contact-info .cta-row{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}

.contact-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:30px;
  box-shadow:var(--shadow-soft);
}
.contact-card h3{font-size:1.5rem;margin-bottom:.3em}
.demo-note{
  font-size:.82rem;
  color:var(--muted);
  background:var(--secondary);
  border-radius:var(--r-sm);
  padding:.7em 1em;
  margin:14px 0 20px;
  border:1px solid var(--line);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:14px}
.field label{
  display:block;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.04em;
  margin-bottom:.4em;
  color:var(--ink);
}
.field input,.field textarea{
  width:100%;
  font-family:"Karla",sans-serif;
  font-size:.96rem;
  color:var(--ink);
  background:var(--canvas);
  border:1px solid var(--line);
  border-radius:var(--r-sm);
  padding:.8em .95em;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.field input:focus,.field textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(177,90,60,.14);
}
.field textarea{resize:vertical;min-height:90px}
.map-wrap{
  margin-top:30px;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  aspect-ratio:16/8;
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.92) contrast(1.02)}

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer{
  background:var(--canvas-deep);
  border-top:1px solid var(--line);
  margin-top:clamp(40px,6vw,80px);
  padding-block:clamp(40px,5vw,64px) 30px;
}
.footer-top{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:36px;
  align-items:start;
}
.footer-brand .brand{font-size:1.5rem;margin-bottom:.5em}
.footer-brand p{color:var(--muted);font-size:.95rem;max-width:38ch}
.footer-col h4{
  font-family:"Karla",sans-serif;
  font-size:.74rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:600;
  margin-bottom:1em;
}
.footer-col a,.footer-col p{
  display:block;
  color:var(--ink);
  font-size:.96rem;
  margin-bottom:.6em;
}
.footer-col a:hover{color:var(--primary)}
.footer-bottom{
  margin-top:clamp(32px,4vw,52px);
  padding-top:24px;
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.disclaimer{
  font-size:.86rem;
  color:var(--muted);
  max-width:60ch;
}
.footer-bottom .credit{font-size:.82rem;color:var(--muted)}

/* ===========================================================
   reveal base (JS sets start state; static stays visible)
   =========================================================== */
.reveal{will-change:transform,opacity}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:980px){
  .hero{grid-template-columns:1fr;gap:34px}
  .hero-media{max-width:480px}
  .story{grid-template-columns:1fr}
  .story-media{order:2;max-width:560px}
  .contact-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  body{font-size:16px}
  .nav-links{display:none}
  .gallery{columns:2}
  .services-grid{grid-template-columns:1fr}
  .approach-steps{grid-template-columns:1fr;gap:24px}
  .form-row{grid-template-columns:1fr}
  .story-stats{gap:24px}
  .footer-top{grid-template-columns:1fr}
}
@media (max-width:460px){
  .wrap{padding-inline:20px}
  .gallery{columns:1}
  .hero-media .tag{left:0}
}
