/* swingthoughtz.com — Social Content & Digital Narratives */
:root{
  --c-ink:#2D3436;
  --c-grey:#636E72;
  --c-primary:#00B894;
  --c-mint:#55EFC4;
  --c-line:#DFE6E9;
  --c-bg:#fbfcfc;
  --c-text:#2D3436;
  --c-muted:#636E72;
  --grad:linear-gradient(135deg,#00B894 0%,#55EFC4 100%);
  --grad-dark:linear-gradient(135deg,#2D3436 0%,#636E72 100%);
  --shadow-sm:0 2px 12px rgba(45,52,54,.06);
  --shadow-md:0 12px 30px rgba(45,52,54,.12);
  --shadow-lg:0 24px 60px rgba(45,52,54,.18);
  --r:8px;
  --r-pill:50px;
  --t:.3s ease;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Lato',-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:300;color:var(--c-text);background:var(--c-bg);line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.18;color:var(--c-ink);letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5.8vw,4rem)}
h2{font-size:clamp(1.8rem,3.8vw,2.8rem);margin-bottom:1rem}
h3{font-size:clamp(1.2rem,2vw,1.5rem);margin-bottom:.6rem}
p{margin-bottom:1rem}
a{color:var(--c-primary);text-decoration:none;transition:var(--t)}
a:hover{color:var(--c-ink)}
img{max-width:100%;height:auto;display:block}
.container{max-width:1240px;margin:0 auto;padding:0 24px}
.section{padding:90px 0}
.section-sm{padding:50px 0}

/* SWISS GRID */
.swiss-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
@media(max-width:760px){.swiss-grid{grid-template-columns:repeat(6,1fr)}}
.col-4{grid-column:span 4}
.col-6{grid-column:span 6}
.col-8{grid-column:span 8}
.col-12{grid-column:span 12}
@media(max-width:760px){
  .col-4,.col-6,.col-8{grid-column:span 6}
}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(251,252,252,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--c-line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:20px 0;gap:18px}
.logo{
  font-family:'Playfair Display',serif;font-weight:700;font-size:1.3rem;color:var(--c-ink);
  display:flex;align-items:center;gap:10px;letter-spacing:-.01em;
}
.logo-mark{
  width:38px;height:38px;border-radius:50%;
  background:var(--grad);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;
  font-family:'Playfair Display',serif;
}
.nav-links{display:flex;gap:4px;list-style:none;align-items:center;flex-wrap:wrap}
.nav-links a{
  padding:8px 14px;border-radius:var(--r-pill);
  font-size:.92rem;color:var(--c-ink);font-weight:400;
}
.nav-links a:hover,.nav-links a.active{background:var(--c-mint);color:var(--c-ink)}
.menu-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--c-ink)}
@media(max-width:1080px){
  .menu-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    background:#fff;flex-direction:column;
    padding:18px;border-bottom:1px solid var(--c-line);display:none;
  }
  .nav-links.open{display:flex}
  .nav-links a{display:block;width:100%}
}

/* BUTTONS — pill + gradient */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;border-radius:var(--r-pill);
  font-family:'Lato',sans-serif;font-weight:600;font-size:.95rem;
  border:0;cursor:pointer;transition:var(--t);
  text-align:center;letter-spacing:.02em;
}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 6px 18px rgba(0,184,148,.28)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,184,148,.38);color:#fff}
.btn-dark{background:var(--c-ink);color:#fff;box-shadow:0 6px 18px rgba(45,52,54,.18)}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(45,52,54,.26)}
.btn-light{background:#fff;color:var(--c-ink);box-shadow:0 6px 18px rgba(0,0,0,.12)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(0,0,0,.16)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7);padding:12px 30px}
.btn-ghost:hover{background:#fff;color:var(--c-ink)}
.btn-outline{background:transparent;color:var(--c-ink);border:2px solid var(--c-ink);padding:12px 30px}
.btn-outline:hover{background:var(--c-ink);color:#fff}

/* HERO */
.hero{
  position:relative;color:#fff;overflow:hidden;
  min-height:600px;display:flex;align-items:center;
  background-size:cover;background-position:center;
  padding:120px 0 100px;
}
.hero::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.55)}
.hero-content{position:relative;z-index:2;max-width:840px;margin:0 auto;text-align:center}
.hero-content h1{color:#fff}
.hero-content .lead{font-size:1.18rem;font-weight:300;opacity:.96;margin:1.2rem auto 2rem;max-width:680px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-full{min-height:100vh}
.hero-article{min-height:460px;padding:100px 0}
.hero-compact{
  position:relative;color:#fff;overflow:hidden;min-height:340px;display:flex;align-items:center;padding:90px 0;
  background:linear-gradient(135deg,var(--c-ink),var(--c-grey));
}
.hero-compact .hero-content h1{color:#fff}

.hero-badge{
  position:absolute;right:30px;top:30px;z-index:3;
  background:#fff;color:var(--c-ink);
  padding:14px 22px;border-radius:var(--r);
  font-family:'Lato',sans-serif;font-weight:700;font-size:.86rem;
  box-shadow:var(--shadow-md);transform:rotate(-3deg);
  border-left:4px solid var(--c-primary);
  animation:wob 4s ease-in-out infinite;
}
@keyframes wob{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}

/* ANIM HEADER */
.anim-header{
  padding:140px 0 80px;text-align:center;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--c-ink) 0%,var(--c-grey) 100%);
}
.anim-header h1{color:#fff;position:relative;z-index:2}
.anim-header .lead{position:relative;z-index:2;opacity:.95;max-width:760px;margin:18px auto 0}
.anim-header .gradient-text{
  background:linear-gradient(90deg,#55EFC4,#fff,#00B894);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;animation:shimmer 5s linear infinite;
}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}

/* BREADCRUMB */
.breadcrumb{display:flex;gap:8px;list-style:none;font-size:.86rem;opacity:.85;justify-content:center;margin-bottom:14px}
.breadcrumb li::after{content:"/";margin-left:8px;opacity:.5}
.breadcrumb li:last-child::after{content:""}
.breadcrumb a{color:inherit}

/* SECTION HEAD */
.section-head{text-align:center;max-width:760px;margin:0 auto 50px}
.section-head .eyebrow{
  display:inline-block;padding:6px 16px;border-radius:var(--r-pill);
  background:var(--c-mint);color:var(--c-ink);
  font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:14px;
}
.section-head p{color:var(--c-muted);font-size:1.05rem;font-weight:400}

/* FLAT CARDS — left accent */
.card{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:30px;box-shadow:var(--shadow-sm);transition:var(--t);
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.card-mint{border-left-color:var(--c-mint);background:#f6fdfb}
.card-icon{
  width:48px;height:48px;border-radius:50%;
  background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-weight:700;font-size:1.1rem;margin-bottom:14px;
}

.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:28px}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px}
.stat-card{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:30px 22px;text-align:center;
  box-shadow:var(--shadow-sm);
}
.stat-num{font-family:'Playfair Display',serif;font-weight:700;font-size:2.5rem;display:block;letter-spacing:-.02em;color:var(--c-primary)}
.stat-label{font-size:.9rem;color:var(--c-muted);margin-top:6px;display:block}

/* FAQ */
.faq-item{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow-sm);
}
.faq-q{
  width:100%;text-align:left;padding:22px 26px;
  background:transparent;border:0;
  font-family:'Playfair Display',serif;font-weight:600;font-size:1.08rem;color:var(--c-ink);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.faq-q::after{content:"+";font-size:1.5rem;color:var(--c-primary);transition:var(--t)}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 26px;max-height:0;overflow:hidden;transition:var(--t);color:var(--c-muted)}
.faq-item.open .faq-a{max-height:500px;padding:0 26px 24px}

/* TABS */
.tabs{max-width:960px;margin:0 auto}
.tab-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:26px}
.tab-btn{
  padding:11px 22px;border-radius:var(--r-pill);
  background:transparent;border:2px solid var(--c-ink);color:var(--c-ink);
  font-family:'Lato',sans-serif;font-weight:600;font-size:.9rem;
  cursor:pointer;transition:var(--t);
}
.tab-btn:hover{background:var(--c-mint)}
.tab-btn.active{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.tab-panel{
  display:none;background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:34px;box-shadow:var(--shadow-sm);
}
.tab-panel.active{display:block;animation:fadeIn .4s}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* FORM */
.form{display:grid;gap:14px;max-width:560px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form label{font-size:.84rem;color:var(--c-muted);font-weight:500;display:block;margin-bottom:6px}
.form input,.form textarea,.form select{
  width:100%;padding:14px 16px;
  border:2px solid var(--c-line);border-radius:var(--r);
  font-family:inherit;font-size:.94rem;background:#fff;color:var(--c-ink);
  transition:var(--t);
}
.form input:focus,.form textarea:focus,.form select:focus{outline:0;border-color:var(--c-primary)}
.form textarea{min-height:140px;resize:vertical}
.form .err{color:#b34040;font-size:.82rem;margin-top:4px;display:none}
.form .err.show{display:block}
.form-ok{padding:14px 18px;border-radius:var(--r);background:#e3fbf3;color:var(--c-ink);display:none;border-left:4px solid var(--c-primary)}
.form-ok.show{display:block}

/* MAP */
.map-wrap{
  border-radius:var(--r);overflow:hidden;
  border-left:4px solid var(--c-primary);
  box-shadow:var(--shadow-sm);min-height:360px;
}
.map-wrap iframe{width:100%;height:100%;min-height:360px;border:0;display:block}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}
.team-card{
  background:#fff;border-radius:var(--r);overflow:hidden;
  border-left:4px solid var(--c-primary);
  box-shadow:var(--shadow-sm);transition:var(--t);
}
.team-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.team-photo{aspect-ratio:1;background:var(--c-mint);overflow:hidden}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-info{padding:22px}
.team-info h3{font-size:1.1rem;margin-bottom:4px}
.team-role{color:var(--c-primary);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.blog-card{
  background:#fff;border-radius:var(--r);overflow:hidden;
  border-left:4px solid var(--c-primary);
  box-shadow:var(--shadow-sm);transition:var(--t);
  display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.blog-img{aspect-ratio:16/10;overflow:hidden}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.blog-card:hover .blog-img img{transform:scale(1.05)}
.blog-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-meta{font-size:.78rem;color:var(--c-primary);margin-bottom:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.blog-body h3{font-size:1.18rem;margin-bottom:10px}
.blog-body p{flex:1;color:var(--c-muted);font-size:.96rem}
.blog-more{margin-top:14px;font-weight:700;color:var(--c-primary)}

/* ARTICLE */
.article{max-width:780px;margin:0 auto;padding:60px 24px}
.article h2{margin-top:2.4rem;font-size:1.8rem;color:var(--c-ink)}
.article h3{margin-top:1.6rem}
.article p,.article li{font-size:1.08rem;color:var(--c-text)}
.article ul,.article ol{margin:1rem 0 1.4rem 1.4rem}
.article blockquote{
  border-left:4px solid var(--c-primary);
  background:#f6fdfb;padding:24px 30px;border-radius:0 var(--r) var(--r) 0;
  margin:2rem 0;color:var(--c-ink);font-style:italic;
  font-family:'Playfair Display',serif;font-size:1.18rem;line-height:1.5;
}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin:1.4rem 0}
.tag{padding:6px 14px;border-radius:var(--r-pill);background:var(--c-mint);color:var(--c-ink);font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}

/* AUTHOR */
.author-card{
  display:flex;gap:20px;align-items:center;
  background:#fff;padding:24px;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  box-shadow:var(--shadow-sm);
}
.author-card img{width:84px;height:84px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-card h3{margin-bottom:4px;font-size:1.1rem}
.author-card .author-role{color:var(--c-primary);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}

/* VIDEO POSTER (no iframe) */
.video-poster{
  position:relative;border-radius:var(--r);overflow:hidden;
  border-left:4px solid var(--c-primary);
  aspect-ratio:16/9;background-size:cover;background-position:center;cursor:pointer;
  box-shadow:var(--shadow-md);
}
.video-poster::before{content:"";position:absolute;inset:0;background:rgba(45,52,54,.5)}
.video-poster .play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:88px;height:88px;border-radius:50%;
  background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;box-shadow:var(--shadow-lg);transition:var(--t);
}
.video-poster:hover .play{transform:translate(-50%,-50%) scale(1.05)}
.video-poster .vp-label{
  position:absolute;left:24px;bottom:20px;color:#fff;z-index:2;
  font-family:'Playfair Display',serif;font-weight:700;font-size:1.15rem;
}

/* BEFORE/AFTER */
.beforeafter{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:760px){.beforeafter{grid-template-columns:1fr}}
.ba-card{
  background:#fff;border-radius:var(--r);overflow:hidden;
  border-left:4px solid var(--c-grey);
  box-shadow:var(--shadow-sm);
}
.ba-card.after{border-left-color:var(--c-primary)}
.ba-head{
  padding:18px 24px;background:var(--c-ink);color:#fff;
  font-family:'Playfair Display',serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:.86rem;
}
.ba-card.after .ba-head{background:var(--grad)}
.ba-body{padding:24px}
.ba-body ul{margin-left:1.4rem;color:var(--c-muted)}
.ba-body li{margin-bottom:6px}

/* BADGES */
.badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}
.badge-box{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:24px 16px;text-align:center;font-size:.88rem;font-weight:600;
  box-shadow:var(--shadow-sm);
}
.badge-box span{font-size:2rem;display:block;margin-bottom:6px;color:var(--c-primary)}

/* PARTNERS */
.partners{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:18px;align-items:center}
.partner{
  background:#fff;border-radius:var(--r);
  border:2px solid var(--c-line);
  padding:22px 14px;text-align:center;
  font-family:'Playfair Display',serif;font-weight:700;color:var(--c-muted);
  transition:var(--t);font-size:.92rem;letter-spacing:.04em;
}
.partner:hover{border-color:var(--c-primary);color:var(--c-primary)}

/* MASONRY */
.masonry{column-count:3;column-gap:18px}
@media(max-width:900px){.masonry{column-count:2}}
@media(max-width:560px){.masonry{column-count:1}}
.masonry img{
  width:100%;border-radius:var(--r);margin-bottom:18px;
  break-inside:avoid;display:block;box-shadow:var(--shadow-sm);transition:var(--t);
}
.masonry img:hover{transform:scale(1.02);box-shadow:var(--shadow-md)}

/* COMPARE */
.compare-table{
  width:100%;border-collapse:collapse;
  background:#fff;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);border-left:4px solid var(--c-primary);
}
.compare-table th,.compare-table td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--c-line)}
.compare-table th{background:var(--c-ink);color:#fff;font-family:'Lato',sans-serif;font-weight:600;text-transform:uppercase;font-size:.84rem;letter-spacing:.06em}
.compare-table tr:last-child td{border-bottom:0}
.check{color:#00875c;font-weight:700}
.cross{color:#b34040;font-weight:700}

/* CTA BANNER */
.cta-banner{
  background:var(--grad);color:#fff;
  border-radius:var(--r);padding:50px;
  display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;
  box-shadow:var(--shadow-md);
}
.cta-banner h2{color:#fff;margin-bottom:6px}
.cta-banner p{opacity:.95;margin-bottom:0}

/* FAB */
.fab-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}
.fab{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:22px 16px;text-align:center;
  box-shadow:var(--shadow-sm);cursor:pointer;transition:var(--t);
  display:block;color:var(--c-ink);
}
.fab:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);background:#f6fdfb}
.fab span.fab-i{display:block;font-size:1.7rem;margin-bottom:6px;color:var(--c-primary)}

/* JOURNEY */
.journey{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;counter-reset:step}
.journey-step{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:34px 22px 22px;position:relative;
  box-shadow:var(--shadow-sm);
}
.journey-step::before{
  counter-increment:step;content:counter(step,decimal-leading-zero);
  position:absolute;top:-14px;left:22px;
  background:var(--c-ink);color:var(--c-mint);
  padding:6px 14px;border-radius:var(--r-pill);
  font-family:'Lato',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.08em;
}

/* TIMELINE */
.timeline-list{position:relative;padding-left:40px}
.timeline-list::before{content:"";position:absolute;left:14px;top:6px;bottom:6px;width:2px;background:var(--c-mint)}
.timeline-item{position:relative;padding-bottom:30px}
.timeline-item::before{
  content:"";position:absolute;left:-32px;top:6px;
  width:14px;height:14px;border-radius:50%;background:var(--c-primary);
  border:3px solid var(--c-mint);
}
.timeline-date{font-family:'Playfair Display',serif;font-weight:700;color:var(--c-primary);font-size:.92rem;letter-spacing:.04em;text-transform:uppercase}
.timeline-item h3{margin:6px 0 8px}

/* CHART */
.chart-card{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:30px;box-shadow:var(--shadow-sm);
}
.bar-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.bar-label{width:160px;font-size:.92rem;color:var(--c-muted);flex-shrink:0}
.bar-bg{flex:1;height:14px;background:var(--c-line);border-radius:var(--r-pill);overflow:hidden}
.bar-fill{height:100%;background:var(--grad);border-radius:var(--r-pill);transition:width 1.2s}
.bar-val{width:48px;text-align:right;font-weight:700;color:var(--c-ink);font-size:.92rem}

/* SPLIT */
.split{display:grid;grid-template-columns:1fr 320px;gap:36px}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.sidebar{display:flex;flex-direction:column;gap:18px}
.side-box{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:24px;box-shadow:var(--shadow-sm);
}
.side-box h3{font-size:1.05rem;margin-bottom:12px}
.side-box ul{list-style:none}
.side-box li{padding:9px 0;border-bottom:1px solid var(--c-line);font-size:.94rem}
.side-box li:last-child{border-bottom:0}

/* ICON LIST */
.icon-list{list-style:none;display:grid;gap:14px}
.icon-list li{
  display:flex;gap:14px;align-items:flex-start;
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:18px;box-shadow:var(--shadow-sm);
}
.icon-list .ic{
  flex-shrink:0;width:44px;height:44px;border-radius:50%;
  background:var(--c-mint);color:var(--c-ink);
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-weight:700;font-size:1rem;
}
.icon-list h4{font-family:'Playfair Display',serif;margin-bottom:4px;font-size:1rem;color:var(--c-ink)}
.icon-list p{margin-bottom:0;color:var(--c-muted);font-size:.92rem}

/* PORTFOLIO */
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.portfolio-item{
  position:relative;border-radius:var(--r);overflow:hidden;
  aspect-ratio:4/3;border-left:4px solid var(--c-primary);
}
.portfolio-item img{width:100%;height:100%;object-fit:cover;transition:.5s}
.portfolio-item:hover img{transform:scale(1.08)}
.portfolio-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(45,52,54,.92));
  display:flex;flex-direction:column;justify-content:flex-end;padding:22px;color:#fff;
}
.portfolio-overlay h3{color:#fff;margin-bottom:4px;font-size:1.05rem}
.portfolio-overlay p{margin:0;font-size:.86rem;opacity:.9}

/* PLANS / PRICING (без сумм — только структура) */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.plan{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:32px 26px;box-shadow:var(--shadow-sm);transition:var(--t);
  display:flex;flex-direction:column;gap:14px;
}
.plan:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.plan.featured{border-left-width:6px;background:#f6fdfb}
.plan-name{font-family:'Playfair Display',serif;font-weight:700;font-size:1.4rem;color:var(--c-ink)}
.plan-tag{
  display:inline-block;padding:5px 12px;border-radius:var(--r-pill);
  background:var(--c-mint);color:var(--c-ink);font-size:.74rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;align-self:flex-start;
}
.plan ul{list-style:none;margin-top:4px;display:grid;gap:8px}
.plan li{font-size:.94rem;color:var(--c-muted);padding-left:22px;position:relative}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--c-primary);font-weight:700}

/* DOWNLOAD */
.dl-row{
  display:flex;justify-content:space-between;align-items:center;
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:18px 24px;margin-bottom:12px;box-shadow:var(--shadow-sm);gap:14px;flex-wrap:wrap;
}
.dl-row strong{display:block;color:var(--c-ink)}
.dl-row small{color:var(--c-muted)}

/* NEWSLETTER */
.newsletter{
  background:var(--grad);color:#fff;
  border-radius:var(--r);padding:50px;text-align:center;
  box-shadow:var(--shadow-md);
}
.newsletter h2{color:#fff}
.newsletter form{max-width:480px;margin:24px auto 0;display:flex;gap:10px;flex-wrap:wrap}
.newsletter input{flex:1;padding:14px 18px;border-radius:var(--r-pill);border:0;font-family:inherit;font-size:.94rem;min-width:220px}
.newsletter .btn{background:var(--c-ink);color:#fff}

/* MEGA FOOTER */
.mega-footer{
  background:var(--c-ink);color:#cfd6d8;
  border-radius:var(--r);padding:50px;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;
}
.mega-footer h4{color:var(--c-mint);margin-bottom:14px;font-size:1rem;text-transform:uppercase;letter-spacing:.08em}
.mega-footer ul{list-style:none}
.mega-footer li{margin-bottom:8px;font-size:.92rem}
.mega-footer a{color:#cfd6d8}
.mega-footer a:hover{color:var(--c-mint)}

/* FOOTER */
.site-footer{
  background:var(--c-ink);color:#cfd6d8;padding:70px 0 30px;margin-top:60px;
}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:36px}
.site-footer h4{color:var(--c-mint);margin-bottom:16px;font-size:1rem;text-transform:uppercase;letter-spacing:.08em}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:8px;font-size:.92rem}
.site-footer a{color:#cfd6d8}
.site-footer a:hover{color:var(--c-mint)}
.footer-bottom{
  border-top:1px solid rgba(85,239,196,.15);
  margin-top:40px;padding-top:20px;text-align:center;font-size:.84rem;opacity:.7;
}

/* COMMENTS */
.comment{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:22px;margin-bottom:12px;box-shadow:var(--shadow-sm);
}
.comment-meta{font-size:.82rem;color:var(--c-primary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}

/* COOKIE */
.cookie-banner{
  position:fixed;bottom:20px;left:20px;right:20px;
  max-width:520px;background:#fff;
  border-radius:var(--r);border-left:4px solid var(--c-primary);
  padding:22px;box-shadow:var(--shadow-lg);z-index:200;display:none;
}
.cookie-banner.show{display:block;animation:slideUp .5s}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}
.cookie-banner p{font-size:.9rem;margin-bottom:12px}

/* LEGAL */
.doc-body{max-width:820px;margin:0 auto}
.doc-body h2{margin-top:2rem;font-size:1.5rem;color:var(--c-ink)}
.doc-body h2 span{
  display:inline-block;width:34px;height:34px;border-radius:50%;
  background:var(--grad);color:#fff;text-align:center;line-height:34px;
  font-size:.92rem;margin-right:10px;font-family:'Lato',sans-serif;font-weight:700;
}
.doc-body ul,.doc-body ol{margin:1rem 0 1rem 1.4rem}
.doc-toc{
  background:#fff;border-radius:var(--r);
  border-left:4px solid var(--c-primary);
  padding:24px;margin-bottom:30px;box-shadow:var(--shadow-sm);
}
.doc-toc ol{margin-left:1.2rem}

/* UTILS */
.text-center{text-align:center}
.bg-soft{background:#f6fdfb}
.bg-line{background:var(--c-line)}
.divider{height:1px;background:var(--c-line);margin:30px 0}
