/*
Theme Name: Anand AR - Full Stack Marketer
Theme URI: https://anandandhalkar.com
Author: Anand Andhalkar
Description: A modern, light, SaaS-style custom theme for a Full Stack Marketer. White background, soft depth, floating cards. Block-editor friendly. No page builder, no bloat.
Version: 2.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: anandar
*/

/* ---------- Design tokens ---------- */
:root{
  --bg:        #ffffff;
  --bg-soft:   #f6f8fb;
  --bg-tint:   #f0f5ff;
  --line:      #e7ebf0;
  --line-soft: #eef1f5;
  --ink:       #0f1729;
  --ink-2:     #46506a;
  --ink-3:     #8a93a6;
  --brand:     #4f46e5;
  --brand-2:   #6366f1;
  --brand-ink: #3730a3;
  --brand-tint:#eef0ff;
  --accent:    #06b6d4;
  --maxw:      1140px;
  --maxw-read: 720px;
  --radius:    16px;
  --radius-sm: 10px;
  --shadow-sm: 0 1px 2px rgba(16,23,41,.05), 0 1px 3px rgba(16,23,41,.06);
  --shadow:    0 4px 12px rgba(16,23,41,.06), 0 12px 32px rgba(16,23,41,.07);
  --shadow-lg: 0 8px 24px rgba(16,23,41,.08), 0 24px 56px rgba(16,23,41,.10);
  --shadow-brand: 0 10px 26px rgba(79,70,229,.28);
  --font-display: "Clash Display", "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:18px; line-height:1.7;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--brand); text-decoration:none; transition:color .2s ease, opacity .2s ease; }
a:hover{ color:var(--brand-2); }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.12; letter-spacing:-.02em; margin:0 0 .5em; color:var(--ink); }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section{ padding:96px 0; }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.8); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; min-height:94px; padding-top:16px; padding-bottom:16px; }
.brand{ display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-weight:600; font-size:1.18rem; color:var(--ink); letter-spacing:-.02em; }
.brand:hover{ color:var(--ink); }
.brand-logo{ display:block; height:44px; width:auto; max-width:240px; object-fit:contain; }
.brand .mark{
  width:40px; height:40px; border-radius:11px; flex:none; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff;
  font-weight:700; font-size:.92rem; letter-spacing:.02em; font-family:var(--font-body);
  box-shadow:var(--shadow-brand);
}
.nav{ display:flex; align-items:center; gap:36px; }
.nav a{ color:var(--ink-2); font-size:.98rem; font-weight:500; }
.nav a:hover{ color:var(--ink); }
/* Header "Email me" = subtle pill, turns solid with black text on hover */
.nav .btn-email{
  background:#fff; color:var(--ink-2); border:1px solid var(--line); box-shadow:var(--shadow-sm);
  padding:11px 20px; font-size:.95rem; font-weight:600; border-radius:11px;
  display:inline-flex; align-items:center; gap:8px; transition:all .2s ease;
}
.nav .btn-email:hover{ color:#0f1729; background:#f6f8fb; border-color:#d7dde6; transform:translateY(-1px); box-shadow:var(--shadow); }
.menu-toggle{ display:none; background:none; border:0; color:var(--ink); cursor:pointer; padding:6px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff;
  font-family:var(--font-body); font-weight:600; font-size:.95rem;
  padding:13px 24px; border-radius:11px; border:0; cursor:pointer;
  box-shadow:var(--shadow-brand); transition:transform .18s ease, box-shadow .18s ease;
}
.btn:hover{ color:#fff; transform:translateY(-2px); box-shadow:0 14px 32px rgba(79,70,229,.36); }
.btn-ghost{ background:#fff; color:var(--ink); border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ color:var(--brand); border-color:var(--brand); box-shadow:var(--shadow); }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:128px 0 104px; overflow:hidden; }
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(680px 360px at 78% 8%, rgba(99,102,241,.12), transparent 62%),
    radial-gradient(520px 420px at 12% 96%, rgba(6,182,212,.08), transparent 60%);
}
.chip{
  display:inline-flex; align-items:center; gap:9px;
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm);
  font-size:.82rem; font-weight:600; color:var(--ink-2);
  padding:7px 15px 7px 12px; border-radius:999px; margin-bottom:28px;
}
.chip .dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(6,182,212,.16); }
.hero h1{ font-size:clamp(2.7rem,6.4vw,4.7rem); margin-bottom:.3em; max-width:15ch; }
.hero h1 .grad{ background:linear-gradient(120deg,var(--brand),var(--accent)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero p{ font-size:clamp(1.08rem,2.4vw,1.34rem); color:var(--ink-2); max-width:56ch; margin:0 0 38px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.trust{ display:flex; gap:26px; flex-wrap:wrap; margin-top:52px; align-items:center; }
.trust .t{ display:flex; flex-direction:column; }
.trust .t b{ font-family:var(--font-display); font-size:1.5rem; color:var(--ink); letter-spacing:-.02em; }
.trust .t span{ font-size:.82rem; color:var(--ink-3); }
.trust .sep{ width:1px; height:34px; background:var(--line); }

/* ---------- Section heads ---------- */
.eyebrow{ display:inline-block; font-size:.78rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--brand); margin-bottom:16px; }
.sec-head{ max-width:62ch; margin-bottom:56px; }
.sec-head h2{ font-size:clamp(2rem,4vw,2.8rem); }
.sec-head p{ color:var(--ink-2); margin:0; }
.center{ text-align:center; margin-left:auto; margin-right:auto; }

/* ---------- Cards grid ---------- */
.grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(264px,1fr)); gap:22px; }
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:32px 30px; box-shadow:var(--shadow-sm);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:#dfe3ea; }
.card .ic{
  width:48px; height:48px; border-radius:13px; margin-bottom:20px; display:grid; place-items:center;
  background:var(--brand-tint); color:var(--brand); box-shadow:inset 0 0 0 1px rgba(79,70,229,.12);
}
.card h3{ font-family:var(--font-body); font-weight:700; font-size:1.12rem; margin-bottom:.45em; letter-spacing:-.01em; }
.card p{ color:var(--ink-2); font-size:.97rem; margin:0; }

/* ---------- How I work band ---------- */
.band{ background:var(--bg-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.two-col{ display:grid; grid-template-columns:1fr 1.15fr; gap:60px; align-items:center; }
.band .lead{ font-family:var(--font-display); font-size:clamp(1.5rem,3vw,2.15rem); line-height:1.32; max-width:18ch; color:var(--ink); margin:0; letter-spacing:-.02em; }
.band .body{ color:var(--ink-2); max-width:54ch; margin:0 0 1em; }
.panel{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:14px;
}
.panel .row{ display:flex; align-items:center; gap:14px; padding:15px 16px; border-radius:var(--radius-sm); }
.panel .row + .row{ margin-top:6px; }
.panel .row .pic{ width:38px; height:38px; border-radius:10px; flex:none; display:grid; place-items:center; background:var(--brand-tint); color:var(--brand); }
.panel .row .meta b{ display:block; font-size:.95rem; }
.panel .row .meta span{ font-size:.82rem; color:var(--ink-3); }
.panel .row .tag{ margin-left:auto; font-size:.74rem; font-weight:700; color:#0f766e; background:#cffafe; padding:4px 10px; border-radius:999px; }
.panel .row:nth-child(2){ background:var(--bg-soft); }

/* ---------- Posts ---------- */
.page-head{ padding:104px 0 8px; }
.page-head h1{ font-size:clamp(2.4rem,6vw,3.7rem); }
.page-head p{ color:var(--ink-2); max-width:54ch; }
.posts{ display:grid; grid-template-columns:repeat(auto-fill,minmax(324px,1fr)); gap:26px; }
.post-card{
  display:flex; flex-direction:column; overflow:hidden; background:#fff;
  border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm);
  transition:transform .22s ease, box-shadow .22s ease;
}
.post-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.post-card a{ color:inherit; }
.post-thumb{ aspect-ratio:16/9; background:var(--bg-soft); overflow:hidden; border-bottom:1px solid var(--line); }
.post-thumb img{ width:100%; height:100%; object-fit:cover; }
.post-thumb.placeholder{ position:relative; background:var(--bg-tint); }
.post-thumb.placeholder::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(360px 200px at 78% 4%, rgba(99,102,241,.22), transparent 62%),
    radial-gradient(300px 220px at 10% 100%, rgba(6,182,212,.16), transparent 60%);
}
.post-body{ padding:26px 28px 30px; display:flex; flex-direction:column; flex:1; }
.post-meta{ font-size:.78rem; color:var(--ink-3); letter-spacing:.04em; text-transform:uppercase; margin-bottom:13px; font-weight:600; }
.post-card h2{ font-size:1.32rem; margin-bottom:.5em; letter-spacing:-.01em; }
.post-card h2 a:hover{ color:var(--brand); }
.post-excerpt{ color:var(--ink-2); font-size:.97rem; margin:0 0 20px; }
.read-more{ margin-top:auto; font-size:.92rem; font-weight:700; color:var(--brand); display:inline-flex; gap:6px; align-items:center; }

/* ---------- Single ---------- */
.article{ padding:84px 0 64px; }
.article-head{ max-width:var(--maxw-read); margin:0 auto 44px; }
.article-head .post-meta{ margin-bottom:18px; }
.article-head h1{ font-size:clamp(2.2rem,5vw,3.3rem); }
.article-hero{ max-width:var(--maxw); margin:0 auto 52px; }
.article-hero img{ width:100%; border-radius:var(--radius); box-shadow:var(--shadow-lg); }
.entry{ max-width:var(--maxw-read); margin:0 auto; }
.entry > *{ margin:0 0 1.4em; }
.entry p{ color:#33405c; }
.entry h2{ font-size:1.8rem; margin-top:1.7em; }
.entry h3{ font-size:1.34rem; font-family:var(--font-body); font-weight:700; margin-top:1.4em; letter-spacing:-.01em; }
.entry a{ text-decoration:underline; text-underline-offset:3px; }
.entry img{ border-radius:12px; box-shadow:var(--shadow); }
.entry blockquote{
  border-left:3px solid var(--brand); margin:1.7em 0; padding:6px 0 6px 26px;
  font-family:var(--font-display); font-size:1.3rem; font-style:normal; color:var(--ink); letter-spacing:-.01em;
}
.entry ul,.entry ol{ padding-left:1.3em; color:#33405c; }
.entry li{ margin-bottom:.5em; }
.entry code{ background:var(--bg-soft); border:1px solid var(--line); padding:2px 7px; border-radius:6px; font-size:.9em; }
.entry pre{ background:#0f1729; color:#e7ebf0; border-radius:12px; padding:22px; overflow:auto; box-shadow:var(--shadow); }
.entry pre code{ background:none; border:0; color:inherit; }
.article-foot{ max-width:var(--maxw-read); margin:58px auto 0; padding-top:28px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }

/* byline */
.byline{ display:flex; align-items:center; gap:12px; margin-top:22px; }
.byline-mark{ width:42px; height:42px; border-radius:11px; flex:none; display:grid; place-items:center; background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; font-weight:700; font-size:.9rem; box-shadow:var(--shadow-brand); }
.byline-meta b{ display:block; font-size:.96rem; color:var(--ink); }
.byline-meta span{ font-size:.82rem; color:var(--ink-3); }

/* reading progress */
.read-progress{ position:fixed; top:0; left:0; right:0; height:3px; background:transparent; z-index:60; }
.read-progress span{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--brand),var(--accent)); transition:width .1s linear; }

/* prev / next */
.post-nav{ max-width:var(--maxw-read); margin:46px auto 0; display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.post-nav-card{ display:flex; flex-direction:column; gap:6px; padding:20px 22px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease; }
.post-nav-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.post-nav-card.right{ text-align:right; }
.post-nav-card .dir{ font-size:.78rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--brand); }
.post-nav-card .ttl{ font-family:var(--font-display); font-weight:600; font-size:1.02rem; color:var(--ink); letter-spacing:-.01em; }
@media (max-width:600px){ .post-nav{ grid-template-columns:1fr; } .post-nav-card.right{ text-align:left; } }

/* ---------- CTA ---------- */
.cta-card{
  max-width:var(--maxw); margin:0 auto; text-align:center;
  background:linear-gradient(135deg,#4f46e5,#6366f1 55%,#06b6d4); color:#fff;
  border-radius:24px; padding:72px 32px; box-shadow:var(--shadow-lg); position:relative; overflow:hidden;
}
.cta-card::after{ content:""; position:absolute; inset:0; background:radial-gradient(600px 300px at 80% -20%, rgba(255,255,255,.18), transparent 60%); pointer-events:none; }
.cta-card h2{ color:#fff; font-size:clamp(2rem,5vw,3rem); margin-bottom:.3em; }
.cta-card p{ color:rgba(255,255,255,.86); max-width:48ch; margin:0 auto 32px; }
.cta-card .btn{ background:#fff; color:var(--brand-ink); box-shadow:0 10px 28px rgba(0,0,0,.18); }
.cta-card .btn:hover{ color:var(--brand-ink); transform:translateY(-2px); }

/* ---------- Footer ---------- */
.site-footer{ border-top:1px solid var(--line); background:var(--bg-soft); padding:60px 0 40px; }
.footer-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:32px; flex-wrap:wrap; margin-bottom:42px; }
.footer-top .brand{ margin-bottom:14px; }
.footer-tag{ color:var(--ink-2); max-width:34ch; font-size:.97rem; margin:0; }
.footer-links{ display:flex; gap:28px; flex-wrap:wrap; }
.footer-links a{ color:var(--ink-2); font-size:.93rem; font-weight:500; }
.footer-links a:hover{ color:var(--brand); }
.footer-bottom{ display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; align-items:center; padding-top:26px; border-top:1px solid var(--line); color:var(--ink-3); font-size:.84rem; }
.made-with{ display:inline-flex; align-items:center; gap:6px; }
.made-with .heart{ color:#e0245e; font-style:normal; font-size:1em; line-height:1; }
/* Scraper-safe email link: shows label, real address assembled on click */
.email-link{ cursor:pointer; }

/* ---------- Pagination ---------- */
.pagination{ display:flex; gap:10px; justify-content:center; margin-top:60px; flex-wrap:wrap; }
.pagination .page-numbers{ padding:10px 16px; border:1px solid var(--line); border-radius:10px; color:var(--ink-2); font-size:.92rem; font-weight:600; background:#fff; box-shadow:var(--shadow-sm); }
.pagination .page-numbers.current{ background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; border-color:transparent; }
.pagination a.page-numbers:hover{ border-color:var(--brand); color:var(--brand); }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:820px){
  body{ font-size:17px; }
  .nav{ position:fixed; inset:74px 0 auto 0; flex-direction:column; align-items:flex-start; gap:0;
    background:#fff; border-bottom:1px solid var(--line); padding:8px 24px 20px; box-shadow:var(--shadow);
    transform:translateY(-140%); transition:transform .3s ease; }
  .nav.open{ transform:none; }
  .nav a{ padding:14px 0; width:100%; border-bottom:1px solid var(--line-soft); }
  .nav .btn, .nav .btn-email{ margin-top:14px; width:100%; justify-content:center; border-bottom:0; }
  .menu-toggle{ display:block; }
  .two-col{ grid-template-columns:1fr; gap:36px; }
  .section{ padding:68px 0; }
  .hero{ padding:88px 0 68px; }
  .footer-top{ flex-direction:column; }
}
