/* ═══════════════════════════════════════════
   Карполис.RU — общие стили сайта
   ═══════════════════════════════════════════ */

:root {
  --accent: #1B4F72;
  --accent2: #0d3152;
  --accent-light: #2E86C1;
  --accent-pale: #EBF5FB;
  --gold: #A08040;
  --gold-light: #F0E8D4;
  --text-dark: #1A1A1A;
  --text-mid: #444;
  --text-muted: #888;
  --bg: #FAFAF8;
  --white: #FFFFFF;
  --border: #E0DDD6;
  --radius: 12px;
  --radius-sm: 6px;
  --shadow: 0 2px 20px rgba(27,79,114,.07);
  --shadow-h: 0 6px 30px rgba(27,79,114,.14);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Jost',sans-serif;background:var(--bg);color:var(--text-dark);font-size:16px;line-height:1.6;}
a{cursor:pointer;}
img{max-width:100%;}

/* ── NAV ── */
nav{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;}
.nav-inner{max-width:1140px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:64px;gap:1rem;}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.55rem;font-weight:600;color:var(--accent);text-decoration:none;letter-spacing:.02em;white-space:nowrap;}
.logo span{color:var(--gold);}
.nav-links{display:flex;gap:.1rem;list-style:none;flex-shrink:0;}
.nav-links a{font-size:.78rem;font-weight:500;letter-spacing:.055em;text-transform:uppercase;color:var(--text-mid);text-decoration:none;padding:.38rem .7rem;border-radius:var(--radius-sm);transition:all .18s;}
.nav-links a:hover,.nav-links a.active{color:var(--accent);background:var(--accent-pale);}
.nav-cta{font-size:.88rem;font-weight:500;color:var(--accent);text-decoration:none;white-space:nowrap;}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;flex-shrink:0;background:none;border:none;}
.burger span{display:block;width:22px;height:2px;background:var(--accent);border-radius:2px;}
.mob-menu{display:none;background:var(--white);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;}
.mob-menu.open{display:block;}
.mob-menu a{display:block;padding:.55rem 0;font-size:.9rem;color:var(--text-mid);text-decoration:none;border-bottom:1px solid var(--border);}
.mob-menu a:last-child{border-bottom:none;}

/* ── LAYOUT ── */
.container{max-width:1140px;margin:0 auto;padding:0 1.5rem;}
.section{padding:3.5rem 0;}

/* ── HERO (home) ── */
.hero{background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);padding:4.5rem 0 3.5rem;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:-80px;right:-80px;width:420px;height:420px;border-radius:50%;background:rgba(255,255,255,.025);}
.hero-grid{display:grid;grid-template-columns:1fr 280px;gap:3.5rem;align-items:center;}
.hero-eyebrow{font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.75rem;}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:300;color:#fff;line-height:1.18;margin-bottom:1.25rem;}
.hero h1 em{font-style:italic;color:#D4AC6E;}
.hero-mission{font-size:.9rem;color:rgba(255,255,255,.82);line-height:1.85;border-left:2px solid var(--gold);padding-left:1.2rem;margin-bottom:2rem;}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.8rem;border-radius:var(--radius-sm);font-family:'Jost',sans-serif;font-size:.88rem;font-weight:500;letter-spacing:.04em;text-decoration:none;transition:all .18s;cursor:pointer;border:none;}
.btn-gold{background:var(--gold);color:#fff;}
.btn-gold:hover{background:#8a6c34;transform:translateY(-1px);}
.btn-ghost{background:transparent;color:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.28);margin-left:.6rem;}
.btn-ghost:hover{background:rgba(255,255,255,.1);}
.agent-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:1.75rem 1.5rem;text-align:center;}
.agent-avatar{width:106px;height:106px;border-radius:50%;overflow:hidden;margin:0 auto .9rem;border:3px solid rgba(160,128,64,.45);}
.agent-avatar img{width:100%;height:100%;object-fit:cover;object-position:top;}
.agent-name{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:#fff;margin-bottom:.2rem;}
.agent-role{font-size:.73rem;color:rgba(255,255,255,.55);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.65rem;}
.agent-phone{display:block;color:#D4AC6E;font-size:1rem;font-weight:500;text-decoration:none;margin-bottom:.3rem;}
.agent-hours{font-size:.75rem;color:rgba(255,255,255,.5);line-height:1.65;}

/* ── SECTION HEADER ── */
.s-label{font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.35rem;}
.s-title{font-family:'Cormorant Garamond',serif;font-size:1.85rem;font-weight:400;color:var(--accent);margin-bottom:.4rem;}
.s-rule{width:44px;height:2px;background:var(--gold);margin:.55rem 0 1.4rem;}
.s-sub{font-size:.88rem;color:var(--text-muted);margin-bottom:2rem;}

/* ── PAGE HEADER ── */
.page-hdr{background:var(--white);border-bottom:1px solid var(--border);padding:2.25rem 0 1.75rem;}
.page-hdr h1{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:400;color:var(--accent);}
.page-hdr p{font-size:.88rem;color:var(--text-muted);margin-top:.2rem;}

/* ── BREADCRUMB ── */
.bc{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--text-muted);margin-bottom:1.25rem;}
.bc a{color:var(--accent-light);text-decoration:none;}
.bc a:hover{text-decoration:underline;}

/* ── PARTNERS GRID ── */
.partners-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:.9rem;}
.p-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem .85rem;display:flex;flex-direction:column;align-items:center;gap:.65rem;text-decoration:none;transition:all .18s;}
.p-card:hover{border-color:var(--accent-light);box-shadow:var(--shadow-h);transform:translateY(-2px);}
.p-logo{width:84px;height:50px;object-fit:contain;display:block;}
.p-name{font-size:.72rem;font-weight:500;color:var(--text-mid);text-align:center;line-height:1.35;}

/* ── PARTNER PAGE ── */
.big-logo{max-width:200px;max-height:90px;object-fit:contain;display:block;margin:0 auto 1.75rem;}
.contract-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem 2rem;max-width:720px;margin:0 auto;}
.c-row{display:flex;padding:.8rem 0;border-bottom:1px solid var(--border);gap:1rem;}
.c-row:last-child{border-bottom:none;}
.c-lbl{font-size:.77rem;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;min-width:175px;flex-shrink:0;padding-top:.05rem;}
.c-val{font-size:.93rem;color:var(--text-dark);line-height:1.5;}
.c-val a{color:var(--accent-light);text-decoration:none;}
.c-val a:hover{text-decoration:underline;}
.agent-box{margin-top:1.25rem;padding:1rem 1.25rem;background:var(--accent-pale);border-radius:var(--radius-sm);border-left:3px solid var(--accent);}
.agent-box .ab-title{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;}
.agent-box .ab-name{font-size:.93rem;font-weight:500;}
.agent-box .ab-inn{font-size:.82rem;color:var(--text-muted);margin-top:.15rem;}
.agent-box .ab-phone{display:inline-block;margin-top:.4rem;color:var(--accent);font-size:.88rem;font-weight:500;text-decoration:none;}

/* ── SERVICE CATALOG ── */
.svc-stack{display:flex;flex-direction:column;gap:1.75rem;}
.svc-group{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.svc-head{background:var(--accent);padding:.9rem 1.4rem;display:flex;align-items:center;gap:.65rem;}
.svc-head h3{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:500;color:#fff;}
.svc-icon{font-size:1.2rem;color:#D4AC6E;}
.svc-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));}
.svc-item{padding:.85rem 1.4rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border);color:var(--text-mid);font-size:.87rem;transition:all .14s;display:flex;align-items:center;gap:.45rem;text-decoration:none;}
.svc-item:hover{background:var(--accent-pale);color:var(--accent);}
.svc-item::before{content:'→';color:var(--gold);font-size:.82rem;flex-shrink:0;}

/* ── PRODUCT PAGE ── */
.prod-hero{background:var(--white);border-bottom:1px solid var(--border);}
.prod-hero-inner{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:340px 1fr;min-height:280px;}
.prod-img-side{overflow:hidden;background:linear-gradient(135deg,var(--accent-pale),#D4E8F5);}
.prod-img-side img{width:100%;height:100%;object-fit:cover;display:block;}
.prod-img-placeholder{width:100%;height:100%;min-height:260px;display:flex;align-items:center;justify-content:center;font-size:5.5rem;}
.prod-text-side{padding:2.25rem 2.75rem;display:flex;flex-direction:column;justify-content:center;}
.prod-text-side .bc{margin-bottom:.75rem;}
.prod-text-side h1{font-family:'Cormorant Garamond',serif;font-size:1.95rem;font-weight:400;color:var(--accent);margin-bottom:.5rem;}
.prod-tagline{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;color:var(--gold);line-height:1.45;}
.prod-body{padding:2.5rem 0;max-width:780px;}
.prod-body p{color:var(--text-mid);line-height:1.9;font-size:.93rem;margin-bottom:1rem;}
.prod-body .placeholder-text{color:var(--text-muted);font-style:italic;}

/* Стили форматированного текста продукта (из редактора Quill в админке) */
.rich-text h2{font-family:'Cormorant Garamond',serif;font-size:1.55rem;font-weight:500;color:var(--accent);margin:1.5rem 0 .75rem;line-height:1.3;}
.rich-text h2:first-child{margin-top:0;}
.rich-text h3{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:500;color:var(--accent);margin:1.25rem 0 .6rem;line-height:1.3;}
.rich-text p{color:var(--text-mid);line-height:1.9;font-size:.93rem;margin-bottom:1rem;}
.rich-text strong, .rich-text b{color:var(--text-dark);font-weight:600;}
.rich-text em, .rich-text i{font-style:italic;}
.rich-text u{text-decoration:underline;}
.rich-text a{color:var(--accent-light);text-decoration:underline;text-decoration-color:rgba(46,134,193,.35);}
.rich-text a:hover{text-decoration-color:var(--accent-light);}
.rich-text ul, .rich-text ol{color:var(--text-mid);line-height:1.9;font-size:.93rem;margin:0 0 1rem 0;padding-left:1.4rem;}
.rich-text li{margin-bottom:.4rem;}
.rich-text .ql-align-center{text-align:center;}
.rich-text .ql-align-right{text-align:right;}
.rich-text .ql-align-justify{text-align:justify;}
.feedback-wrap{background:var(--white);border-top:1px solid var(--border);padding:3rem 0;}
.feedback-wrap h2{font-family:'Cormorant Garamond',serif;font-size:1.55rem;color:var(--accent);margin-bottom:.3rem;}
.feedback-wrap p{font-size:.87rem;color:var(--text-muted);margin-bottom:1.5rem;}

/* ── ABOUT ── */
.about-top{background:var(--accent-pale);border-bottom:1px solid var(--border);padding:3rem 0 2.5rem;}
.about-grid{display:grid;grid-template-columns:260px 1fr;gap:3rem;align-items:start;}
.about-photo-wrap{position:relative;}
.about-photo{width:100%;border-radius:var(--radius);display:block;}
.about-badge{position:absolute;bottom:-1rem;right:-1rem;background:var(--gold);color:#fff;padding:.65rem 1.1rem;border-radius:var(--radius-sm);font-size:.76rem;letter-spacing:.05em;text-transform:uppercase;font-weight:500;}
.about-text-eyebrow{color:var(--text-muted);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem;}
.about-text h1{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:400;color:var(--accent);line-height:1.2;margin-bottom:.4rem;}
.about-text h1 em{font-style:italic;color:var(--accent-light);}
.about-text p{color:var(--text-mid);line-height:1.9;font-size:.93rem;margin-bottom:.9rem;}
.meta-chips{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem;}
.meta-chip{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem 1rem;}
.meta-chip .mc-l{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;}
.meta-chip .mc-v{font-size:.88rem;font-weight:500;margin-top:.1rem;}
.meta-chip a{color:var(--accent);text-decoration:none;}
.stat-bar{border-bottom:1px solid var(--border);background:var(--white);}
.stat-bar-inner{max-width:1140px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:repeat(4,1fr);}
.stat-item{text-align:center;padding:1.4rem .5rem;border-right:1px solid var(--border);}
.stat-item:last-child{border-right:none;}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;color:var(--accent);}
.stat-lbl{font-size:.75rem;color:var(--text-muted);margin-top:.15rem;line-height:1.35;}
.map-grid{display:grid;grid-template-columns:1fr 2fr;gap:2rem;align-items:start;}
.office-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem;}
.office-card .oc-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem;}
.office-card .oc-addr{font-size:.95rem;font-weight:500;line-height:1.55;margin-bottom:1rem;}
.office-card .oc-note{font-size:.82rem;color:var(--text-muted);line-height:1.6;padding-top:.9rem;border-top:1px solid var(--border);margin-bottom:1rem;}
.map-frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);}

/* ── SHOP ── */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.4rem;}
.shop-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .18s,transform .18s;}
.shop-card:hover{box-shadow:var(--shadow-h);transform:translateY(-2px);}
.shop-img{width:100%;height:190px;object-fit:cover;display:block;}
.shop-img-placeholder{width:100%;height:190px;background:linear-gradient(135deg,var(--accent-pale),#D4E8F5);display:flex;align-items:center;justify-content:center;font-size:3rem;}
.shop-body{padding:1.15rem 1.4rem;flex:1;display:flex;flex-direction:column;gap:.65rem;}
.shop-tag{display:inline-block;background:var(--gold-light);color:var(--gold);font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;padding:.22rem .55rem;border-radius:4px;}
.shop-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:500;color:var(--accent);line-height:1.3;}
.shop-desc{font-size:.86rem;color:var(--text-mid);line-height:1.7;flex:1;}
.shop-foot{padding:0 1.4rem 1.25rem;}
.shop-btn{display:block;text-align:center;padding:.65rem 1.4rem;background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-size:.86rem;font-weight:500;letter-spacing:.04em;text-decoration:none;transition:background .18s;}
.shop-btn:hover{background:var(--accent2);}
.shop-note{font-size:.75rem;color:var(--text-muted);text-align:center;margin-top:.45rem;}
.shop-cta{margin-top:2.5rem;padding:1.4rem 1.75rem;background:var(--accent-pale);border-radius:var(--radius);border-left:3px solid var(--accent);}
.shop-cta h3{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--accent);margin-bottom:.35rem;}
.shop-cta p{font-size:.88rem;color:var(--text-mid);}

/* ── PRIVACY ── */
.priv-body{max-width:760px;margin:0 auto;}
.priv-body h2{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--accent);margin:1.75rem 0 .65rem;font-weight:500;}
.priv-body p,.priv-body li{font-size:.88rem;color:var(--text-mid);line-height:1.88;margin-bottom:.65rem;}
.priv-body ol,.priv-body ul{padding-left:1.4rem;}
.priv-note{margin-top:1.75rem;padding:1rem 1.25rem;background:var(--accent-pale);border-radius:var(--radius-sm);border-left:3px solid var(--accent);font-size:.84rem;color:var(--text-mid);}
.priv-note a{color:var(--accent);}

/* ── FOOTER ── */
footer{background:var(--accent);color:rgba(255,255,255,.65);padding:2.25rem 0;margin-top:4rem;}
.foot-inner{max-width:1140px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;}
.foot-logo{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:#fff;font-weight:500;}
.foot-logo span{color:#D4AC6E;}
.foot-links{display:flex;gap:1.25rem;flex-wrap:wrap;}
.foot-links a{font-size:.78rem;color:rgba(255,255,255,.55);text-decoration:none;letter-spacing:.04em;transition:color .18s;}
.foot-links a:hover{color:#D4AC6E;}
.foot-copy{font-size:.72rem;color:rgba(255,255,255,.35);}

/* ── RESPONSIVE ── */
@media(max-width:920px){
  .hero-grid,.prod-hero-inner,.about-grid,.map-grid{grid-template-columns:1fr;}
  .prod-img-placeholder{min-height:200px;}
  .stat-bar-inner{grid-template-columns:repeat(2,1fr);}
  .stat-item:nth-child(2){border-right:none;}
  .stat-item:nth-child(3){border-top:1px solid var(--border);}
  .nav-links{display:none;}
  .burger{display:flex;}
  .nav-cta{display:none;}
  .hero h1{font-size:2.1rem;}
  .about-grid{gap:2rem;}
}
@media(max-width:480px){
  .partners-grid{grid-template-columns:repeat(3,1fr);}
  .stat-bar-inner{grid-template-columns:repeat(2,1fr);}
  .foot-inner{flex-direction:column;text-align:center;}
}
