:root{
  --bg:#fbfaf7;
  --surface:#ffffff;
  --text:#0f0f10;
  --muted:rgba(15,15,16,.64);
  --line:rgba(15,15,16,.12);
  --line-strong:rgba(15,15,16,.18);
  --accent:#d23b2f;
  --header-bg:rgba(10,10,10,.92);
  --header-text:rgba(255,255,255,.92);
  --header-muted:rgba(255,255,255,.72);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family: Manrope, system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  line-height:1.6;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}

.container{width:min(1120px, 92%); margin:0 auto;}

h1,h2,h3{
  font-family:"Cormorant Garamond", Georgia, serif;
  font-weight:600;
  letter-spacing:.01em;
  line-height:1.08;
  margin:0 0 .65rem 0;
}

p{margin:.6rem 0; color:var(--muted)}
a{color:inherit}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--header-bg);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(255,255,255,.10);
}

.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:68px;
  padding:8px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  min-width:0;
}

.brand img{
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
}

.brand-text{
  font-family: Manrope, system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--header-text);
  white-space:nowrap;
}

nav{min-width:0}

.nav-links{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  align-items:center;
  gap:16px;
  white-space:nowrap;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.nav-links::-webkit-scrollbar{display:none}

.nav-links a{
  text-decoration:none;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--header-muted);
  padding:10px 4px;
  display:inline-block;
  border-bottom:1px solid transparent;
}

.nav-links a.active{
  color:var(--header-text);
  border-bottom-color:rgba(255,255,255,.38);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(15,15,16,.18);
  color:var(--text);
  text-decoration:none;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  background:transparent;
}
.btn:hover{border-color:rgba(15,15,16,.32)}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:9px 12px}

main{padding-bottom:64px}

/* Page hero spacing (top space after header) */
.page-hero{
  padding:56px 0 18px;
}
@media (max-width:520px){
  .page-hero{padding:44px 0 14px;}
}


/* HERO */
.hero{
  position:relative;
  padding:38px 0 34px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}

/* ФОТО НА ФОНЕ */
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("assets/photka1.png");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  z-index:0;
}

/* МЯГКИЙ ОВЕРЛЕЙ ДЛЯ ЧИТАЕМОСТИ */
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(251,250,247,0.88);
  z-index:1;
}

/* КОНТЕНТ ПОВЕРХ */
.hero > .container{
  position:relative;
  z-index:2;
}


.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:26px;
  align-items:start;
}
.kicker{
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--muted);
}
.hero h1{
  font-size:46px;
  margin-top:10px;
}
.hero .lead{
  font-size:15px;
  color:var(--muted);
  max-width:56ch;
}
.hero-actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:16px}

.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px;
}
.card h3{font-size:24px}
.card p{margin:0}

.section{
  padding:44px 0;
  border-bottom:1px solid var(--line);
}
.section:last-child{border-bottom:none}

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

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  border:1px solid var(--line);
  padding:8px 12px;
  border-radius:999px;
}

.footer{
  padding:30px 0 44px;
}
.footer-top{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  border-top:1px solid var(--line);
  padding-top:22px;
}
.footer a{color:var(--text); text-decoration:none; border-bottom:1px solid transparent}
.footer a:hover{border-bottom-color:var(--line-strong)}
.footer small{color:var(--muted)}

/* CONTACT FORM */
.form{
  display:grid;
  gap:12px;
}
label{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted)}
input, textarea, select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-family:inherit;
  font-size:14px;
}
textarea{min-height:120px; resize:vertical}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:12px}

.btn-primary{
  border-color:rgba(210,59,47,.55);
  color:var(--text);
  background:rgba(210,59,47,.06);
}
.btn-primary:hover{border-color:rgba(210,59,47,.85); background:rgba(210,59,47,.10)}

/* reveal (kept) */
.reveal{opacity:0; transform:translateY(10px); transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1; transform:none}

/* Toast */
.toast{
  position:fixed;
  left:50%;
  bottom:22px;
  transform:translateX(-50%) translateY(10px);
  background:rgba(10,10,10,.92);
  color:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.12);
  padding:12px 14px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.02em;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
  z-index:200;
}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}


/* Compatibility with existing markup */
.hero-layout{display:grid; grid-template-columns:1.2fr .8fr; gap:26px; align-items:start}
.subtitle{font-size:15px; color:var(--muted); max-width:56ch}
.hero-visual{background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:18px}
.hero-visual img{width:100%; max-width:180px; height:auto; display:block; margin:0 auto 12px}
.glass{background:var(--surface)} /* legacy */
.btn-ghost{border-color:rgba(15,15,16,.12); background:transparent; color:var(--text)}
.hero .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(15,15,16,.18);
  color:var(--text);
  text-decoration:none;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  background:transparent;
}
.btn:hover{border-color:rgba(15,15,16,.32)}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:9px 12px}
.hero .btn:hover{border-color:rgba(15,15,16,.30)}
.hero .btn.btn-ghost{border-color:rgba(15,15,16,.12); background:transparent; color:var(--text)}
.accent-text{display:inline-block; white-space:nowrap; color:var(--accent)}

.hero-photo-wrap{
  width:100%;
  aspect-ratio:1/1;       /* квадрат */
  max-width:420px;        /* примерно размер старой карточки */
  justify-self:end;       /* справа */
}

.hero-photo-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Каталог: 3 карточки в ряд на десктопе, 2 на телефоне */
.catalog-cards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}

@media (max-width: 520px){
  .catalog-cards{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px;
  }
}

/* ====== CATALOG FIX: одинаковые превью, ничего не наезжает ====== */

/* сетка уже есть — оставляем */
.catalog-cards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
  align-items:stretch;
}

@media (max-width: 520px){
  .catalog-cards{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px;
  }
}

/* сама карточка: не даём контенту вылезать */
.catalog-card{
  overflow:hidden;
  display:flex;
  flex-direction:column;
  height:100%;
}

/* Catalog images can be wrapped in a link */
.catalog-img-link{display:block; text-decoration:none; color:inherit}
.catalog-card img{
  width:100%;
  height:180px;
  object-fit:cover;
  display:block;
  border-bottom:1px solid var(--line);
}
@media (max-width: 520px){
  .catalog-card img{height:140px;}
}

/* Align "Заказать" buttons to the same baseline */
.catalog-body .btn{margin-top:auto;}


/* тело карточки пусть растягивается ровно */
.catalog-body{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:14px 14px 16px;
  flex:1;
}

/* кнопка заказа вниз */
.catalog-body .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(15,15,16,.18);
  color:var(--text);
  text-decoration:none;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  background:transparent;
}
.btn:hover{border-color:rgba(15,15,16,.32)}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:9px 12px}


/* Mobile */
@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr; gap:16px}
  .hero-layout{grid-template-columns:1fr; gap:16px}
  .grid-3{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .nav-wrap{min-height:62px}
  .hero{padding-top:26px}
  .hero h1{font-size:38px}
  .nav-links{gap:12px}
  .nav-links a{font-size:10px; padding:10px 2px}
  .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(15,15,16,.18);
  color:var(--text);
  text-decoration:none;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  background:transparent;
}
.btn:hover{border-color:rgba(15,15,16,.32)}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:9px 12px}
}




/* Header buttons should be white */
.site-header .btn{
  border-color: rgba(255,255,255,.28);
  color: var(--header-text);
}
.site-header .btn:hover{border-color: rgba(255,255,255,.48);}


/* Header (mobile without burger) */
.nav-toggle{display:none !important;}

@media (max-width: 520px){
  .nav-wrap{
    flex-wrap:wrap;
    gap:10px;
    align-items:center;
    padding-top:14px;
    padding-bottom:14px;
  }
  .brand{
    flex: 1 1 auto;
    min-width: 0;
  }
  .brand-text{
    display:inline;
    font-size:12px;
    letter-spacing:.18em;
  }
  .brand img{width:34px; height:34px;}
  .site-header .btn.btn-sm{
    order:2;
    padding:9px 12px;
    border-radius:999px;
  }

  .site-nav{
    position:static;
    display:block !important;
    width:100%;
    order:3;
  }
  .nav-links{
    flex-wrap:wrap;
    white-space:normal;
    gap:14px 18px;
    padding-top:6px;
  }
  .nav-links a{
    padding:8px 0;
  }
}


/* Footer (fix alignment + spacing) */
.site-footer{
  border-top:1px solid var(--line);
  padding:22px 0 34px;
  margin-top:26px;
}
.footer-grid{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.footer-grid strong{color:var(--text); font-size:13px}
.footer-note{color:var(--muted); font-size:13px}
@media (max-width:520px){
  .footer-grid{flex-direction:column; align-items:flex-start;}
}

/* About page split with photo */
.about-split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:center;
}
.about-media{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--surface);
}
.about-media img{width:100%; height:100%; display:block; object-fit:cover}
.about-copy .btn{margin-top:10px}
@media (max-width:900px){
  .about-split{grid-template-columns:1fr;}
}


/* "А ещё:" chips */
.also-block{
  display:flex;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
}
.also-label{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  padding-top:6px;
}
.chips{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.chips li{
  border:1px solid var(--line);
  background:rgba(255,255,255,.6);
  padding:10px 12px;
  border-radius:999px;
  font-size:12px;
  color:rgba(15,15,16,.74);
  line-height:1;
}
@media (max-width:520px){
  .chips li{font-size:11px; padding:9px 11px;}
}


/* About hero with background photo like on main */
.hero-about::before{
  background-image:url("assets/ostudio.png");
}


/* Contact page: left info + right form, bottom full-width notes */
.contact-two-col{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap:18px;
  align-items:start;
}
.contact-left{
  display:grid;
  gap:14px;
}
.contact-notes{
  border:1px solid var(--line);
  background:rgba(255,255,255,.65);
  border-radius:18px;
  padding:18px;
}
.contact-notes h3{margin-top:0}
.contact-notes ul{margin:10px 0 0 18px; color:var(--muted)}
@media (max-width:900px){
  .contact-two-col{grid-template-columns:1fr;}
}


/* Services spacing tweaks */
.section.services-cta{padding:34px 0 32px;}



/* Contact layout */
.contact-layout{
  display:grid;
  grid-template-columns: 1fr 1.15fr;
  gap:28px;
  align-items:start;
}
.contact-meta{
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px;
  background:rgba(255,255,255,.65);
  backdrop-filter: blur(8px);
}
.contact-meta h2{
  margin:0 0 10px;
  font-size:18px;
}
.contact-list{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin:0;
  padding:0;
  list-style:none;
}
.contact-item{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(15,15,16,.08);
  background:rgba(255,255,255,.5);
}
.contact-item strong{font-size:12px; letter-spacing:.14em; text-transform:uppercase; opacity:.75}
.contact-item a{color:var(--text); text-decoration:none}
.contact-item a:hover{text-decoration:underline}
.contact-tips{
  margin-top:22px;
  border-top:1px solid var(--line);
  padding-top:18px;
}
.contact-tips h3{margin:0 0 10px; font-size:16px}
.contact-tips ul{margin:0; padding-left:18px}
.contact-tips li{margin:6px 0}

@media (max-width: 860px){
  .contact-layout{grid-template-columns:1fr; }
}

/* About hero with background image */
.about-hero{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.about-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: url('assets/ostudio.png');
  background-size:cover;
  background-position:center;
  filter: grayscale(1) contrast(1.05);
  transform: scale(1.02);
}
.about-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(250,248,244,.92) 0%, rgba(250,248,244,.86) 50%, rgba(250,248,244,.60) 100%);
}
.about-hero .container{
  position:relative;
  z-index:1;
  padding:52px 0;
}
.about-hero-layout{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:24px;
  align-items:center;
}
.about-hero .badge{background:rgba(15,15,16,.06)}
.about-hero .subtitle{max-width:56ch}
.about-hero-photo img{
  width:100%;
  height:auto;
  background: transparent;
}
@media (max-width: 860px){
  .about-hero .container{padding:40px 0;}
  .about-hero-layout{grid-template-columns:1fr;}
  .about-hero-photo{max-width:420px}
}


.form-message{margin:10px 0 0; font-size:13px; opacity:.85}
.form-message.ok{color:var(--text)}
.form-message.err{color:var(--accent)}
