/* ── TOKENS ───────────────────────────────── */
:root{
  --bg:        #f5f6fa;
  --bg2:       #ffffff;
  --bg3:       #eef0f7;
  --slate:     #2d4a7a;
  --slate-dk:  #1b2f50;
  --blue:      #1e7fd4;
  --blue-lt:   #e8f3fc;
  --orange:    #f47a20;
  --orange-lt: #fef0e6;
  --ink:       #1a2233;
  --ink2:      #4a5568;
  --ink3:      #8896a8;
  --border:    #dde3ef;
  --white:     #ffffff;
  --shadow-sm: 0 2px 8px rgba(45,74,122,.07);
  --shadow-md: 0 8px 32px rgba(45,74,122,.11);
  --shadow-lg: 0 20px 60px rgba(45,74,122,.14);
  --r:         cubic-bezier(0.16,1,0.3,1);
  --sp:        cubic-bezier(0.34,1.56,0.64,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;font-size:16px}
body{background:var(--bg);color:var(--ink);font-family:"Plus Jakarta Sans",sans-serif;font-weight:400;line-height:1.7;overflow-x:hidden}
::selection{background:rgba(30,127,212,.18);color:var(--slate-dk)}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:2px}
img{max-width:100%;display:block}

/* ── NAV ──────────────────────────────────── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:0 5vw;height:68px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .4s var(--r),box-shadow .4s var(--r),height .4s var(--r);
}
#nav.scrolled{
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--border),var(--shadow-sm);
  height:60px;
}
.nav-logo{font-family:"Fraunces",serif;font-size:1.05rem;font-weight:700;text-decoration:none}
.nl-text{color:var(--slate-dk)}
.nl-dot{color:var(--orange)}
.nl-np{color:var(--blue)}
.nav-links{display:flex;align-items:center;gap:2.2rem;list-style:none}
.nav-links a{
  font-size:.82rem;font-weight:600;letter-spacing:.04em;
  color:var(--ink2);text-decoration:none;
  position:relative;padding-bottom:2px;transition:color .25s;
}
.nav-links a::after{
  content:"";position:absolute;bottom:0;left:0;
  width:0;height:2px;border-radius:1px;
  background:var(--orange);transition:width .35s var(--r);
}
.nav-links a:hover,.nav-links a.act{color:var(--slate-dk)}
.nav-links a:hover::after,.nav-links a.act::after{width:100%}
.nav-hire{
  background:#fff3e8!important;color:#c85e0f!important;
  border:1.5px solid #f47a20!important;
  padding:.5rem 1.2rem;border-radius:6px;
  font-size:.82rem!important;font-weight:600!important;
  display:inline-flex!important;align-items:center!important;justify-content:center!important;
  white-space:nowrap;gap:.3rem;
  transition:transform .3s var(--sp),box-shadow .3s!important;
}
.nav-hire::after{display:none!important}
.nav-hire:hover{transform:translateY(-2px)!important;box-shadow:0 6px 20px rgba(244,122,32,.25)!important;background:#ffe8d0!important}
.hb{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;width:44px;height:44px;padding:6px;border-radius:8px;transition:background .2s}
.hb:hover{background:var(--bg3)}
.hb span{display:block;height:2px;background:var(--ink);border-radius:1px;transition:all .35s var(--r)}
.hb span:nth-child(1){width:22px}
.hb span:nth-child(2){width:16px}
.hb span:nth-child(3){width:20px}
.hb.o span:nth-child(1){width:22px;transform:translateY(7px) rotate(45deg)}
.hb.o span:nth-child(2){opacity:0;transform:scaleX(0)}
.hb.o span:nth-child(3){width:22px;transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE DRAWER ────────────────────────── */
.drawer{
  display:none;position:fixed;inset:0;z-index:800;
  background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  flex-direction:column;align-items:center;justify-content:center;gap:2rem;
  padding:2rem;
}
.drawer.o{display:flex}
.drawer a{
  font-family:"Fraunces",serif;font-size:1.8rem;font-weight:700;
  color:var(--ink);text-decoration:none;transition:color .25s;
}
.drawer a:hover{color:var(--orange)}
.drawer .drawer-hire{
  font-family:"Plus Jakarta Sans",sans-serif !important;
  font-size:.9rem !important;font-weight:700 !important;
  background:var(--orange) !important;color:#fff !important;
  padding:.85rem 2.2rem !important;border-radius:100px !important;
  margin-top:.5rem;box-shadow:0 4px 18px rgba(244,122,32,.28);
}
.drawer .drawer-hire:hover{color:#fff !important;transform:translateY(-2px)}

/* ── SHARED ────────────────────────────────── */
.sec{padding:6rem 5vw}
.wrap{max-width:1160px;margin:0 auto}
.tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue);margin-bottom:.9rem;
}
.tag::before{content:"";width:18px;height:2px;background:var(--orange);border-radius:1px}
h2.sec-h{
  font-family:"Fraunces",serif;
  font-size:clamp(2rem,4vw,2.9rem);font-weight:700;
  line-height:1.12;color:var(--slate-dk);margin-bottom:1.2rem;
}
h2.sec-h em{font-style:italic;color:var(--orange)}
.sec-sub{color:var(--ink2);font-size:.97rem;line-height:1.85;max-width:520px;margin-bottom:1rem}
.rv{opacity:0;transform:translateY(24px);transition:opacity .75s var(--r),transform .75s var(--r)}
.rvL{opacity:0;transform:translateX(-24px);transition:opacity .75s var(--r),transform .75s var(--r)}
.rvR{opacity:0;transform:translateX(24px);transition:opacity .75s var(--r),transform .75s var(--r)}
.rv.in,.rvL.in,.rvR.in{opacity:1;transform:none}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}
[data-d="3"]{transition-delay:.24s}[data-d="4"]{transition-delay:.32s}
[data-d="5"]{transition-delay:.40s}

/* ── BUTTONS ──────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--orange);color:#fff;
  font-size:.85rem;font-weight:700;
  padding:.9rem 2rem;border-radius:100px;text-decoration:none;
  box-shadow:0 4px 18px rgba(244,122,32,.28);
  transition:transform .35s var(--sp),box-shadow .35s;
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(244,122,32,.38)}
.btn-outline{
  display:inline-flex;align-items:center;gap:.55rem;
  background:transparent;color:var(--slate);
  font-size:.85rem;font-weight:700;
  padding:.9rem 2rem;border-radius:100px;text-decoration:none;
  border:2px solid var(--border);
  transition:all .35s var(--r);
}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-3px);background:var(--blue-lt)}

/* ── HERO ─────────────────────────────────── */
#home{
  min-height:100svh;padding-top:68px;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
}
.hero-geo{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 55% at 70% 45%, rgba(30,127,212,.07) 0%, transparent 65%),
    radial-gradient(ellipse 40% 40% at 15% 70%, rgba(244,122,32,.06) 0%, transparent 55%);
}
.hero-dots{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle, rgba(45,74,122,.13) 1.2px, transparent 1.2px);
  background-size:28px 28px;
  mask-image:radial-gradient(ellipse 75% 75% at 60% 45%, black 20%, transparent 75%);
}
.hero-inner{
  max-width:1160px;margin:0 auto;width:100%;padding:4rem 0 5rem;
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--white);border:1.5px solid var(--border);
  padding:.38rem 1rem .38rem .7rem;border-radius:100px;
  font-size:.73rem;font-weight:600;color:var(--ink2);
  box-shadow:var(--shadow-sm);margin-bottom:2rem;
  animation:slideDown .7s var(--r) .1s both;
}
.badge-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:bpulse 2s ease-in-out infinite}
@keyframes bpulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.35)}50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}}
.hero-h1{
  font-family:"Fraunces",serif;
  font-size:clamp(2.6rem,5.5vw,4.2rem);
  font-weight:700;line-height:1.06;
  color:var(--slate-dk);letter-spacing:-.02em;
  animation:slideDown .9s var(--r) .25s both;
}
.hero-h1 em{font-style:italic;color:var(--orange)}
.hero-h1 .blue{color:var(--blue)}
.hero-desc{
  font-size:1.02rem;color:var(--ink2);line-height:1.85;
  margin:1.6rem 0 2.5rem;max-width:460px;
  animation:slideDown .9s var(--r) .4s both;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;animation:slideDown .9s var(--r) .55s both}
.hero-roles{
  display:flex;flex-wrap:wrap;gap:.6rem;
  margin-top:2.4rem;
  animation:slideDown .9s var(--r) .7s both;
}
.role-chip{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.38rem .9rem;border-radius:8px;
  font-size:.76rem;font-weight:600;
}
.rc-web{background:var(--blue-lt);color:var(--blue)}
.rc-yt{background:#fde8e8;color:#c0392b}
.rc-bake{background:#fef3e2;color:#c05c00}
.hero-cards{position:relative;height:420px}
.hcard{
  position:absolute;background:var(--white);
  border:1.5px solid var(--border);border-radius:20px;
  box-shadow:var(--shadow-md);padding:1.4rem 1.6rem;
  animation:slideDown .9s var(--r) var(--ad,0s) both;
}
.hc-main{
  width:78%;left:50%;top:50%;transform:translate(-50%,-50%);
  --ad:.3s;
}
.hc-main h3{font-family:"Fraunces",serif;font-size:1.25rem;font-weight:700;color:var(--slate-dk);margin-bottom:.4rem}
.hc-main p{font-size:.82rem;color:var(--ink2);line-height:1.6}
.hc-pills{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}
.hcp{font-size:.68rem;font-weight:700;padding:.25rem .7rem;border-radius:6px}
.hcp.w{background:var(--blue-lt);color:var(--blue)}
.hcp.y{background:#fde8e8;color:#c0392b}
.hcp.b{background:#fef3e2;color:#c05c00}
.hc-tl{width:48%;top:2%;left:-4%;--ad:.5s;animation:floatA 5s ease-in-out infinite .5s}
.hc-br{width:46%;bottom:2%;right:-3%;--ad:.7s;animation:floatB 6s ease-in-out infinite}
.hc-tr{width:40%;top:5%;right:-2%;--ad:.6s;animation:floatA 7s ease-in-out infinite 1s}
.stat-ico{font-size:1.3rem;margin-bottom:.4rem}
.stat-n{font-family:"Fraunces",serif;font-size:1.6rem;font-weight:700;color:var(--slate-dk);line-height:1}
.stat-l{font-size:.72rem;color:var(--ink3);margin-top:.2rem}
.hc-loc{
  width:44%;bottom:6%;left:-2%;--ad:.65s;
  animation:floatB 5.5s ease-in-out infinite .8s;
  display:flex;align-items:center;gap:.7rem;
}
.loc-ico{width:34px;height:34px;background:var(--orange-lt);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.loc-t{font-size:.8rem;font-weight:700;color:var(--slate-dk)}
.loc-s{font-size:.7rem;color:var(--ink3)}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
@keyframes slideDown{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ── ABOUT ────────────────────────────────── */
#about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:5.5rem;align-items:center}
.portrait{position:relative;max-width:400px}
.portrait-box{
  width:100%;aspect-ratio:3/3.8;border-radius:24px;overflow:hidden;
  background:linear-gradient(145deg,var(--blue-lt) 0%,var(--bg3) 100%);
  border:1.5px solid var(--border);position:relative;
  display:flex;align-items:center;justify-content:center;
}
.portrait-box::after{
  content:"";position:absolute;inset:0;border-radius:24px;
  background:linear-gradient(to bottom,transparent 55%,rgba(45,74,122,.08));
}
.avatar-ring{
  width:140px;height:140px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--slate));
  display:flex;align-items:center;justify-content:center;
  font-family:"Fraunces",serif;font-size:3.5rem;font-weight:700;
  color:#fff;box-shadow:0 12px 40px rgba(30,127,212,.28);
  animation:floatA 5s ease-in-out infinite;
  position:relative;z-index:1;
}
.portrait-name{position:relative;z-index:1;text-align:center;margin-top:1rem;padding:0 1rem}
.portrait-name strong{display:block;font-family:"Fraunces",serif;font-size:1.05rem;font-weight:700;color:var(--slate-dk)}
.portrait-name span{font-size:.75rem;color:var(--ink3)}
.avail-badge{
  position:absolute;bottom:-1rem;left:50%;transform:translateX(-50%);
  background:var(--white);border:1.5px solid var(--border);
  border-radius:100px;padding:.5rem 1.1rem;
  display:flex;align-items:center;gap:.6rem;
  box-shadow:var(--shadow-sm);white-space:nowrap;
}
.avail-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:bpulse 2s ease-in-out infinite}
.avail-txt{font-size:.74rem;font-weight:600;color:var(--ink2)}
.fc{
  position:absolute;background:var(--white);
  border:1.5px solid var(--border);border-radius:12px;
  padding:.5rem .9rem;font-size:.73rem;font-weight:700;
  box-shadow:var(--shadow-sm);white-space:nowrap;
}
.fc1{top:1.2rem;left:-2.5rem;color:var(--blue);animation:floatA 5s ease-in-out infinite}
.fc2{top:5.5rem;right:-2.8rem;color:var(--orange);animation:floatB 6s ease-in-out infinite .8s}
.fc3{bottom:4.5rem;left:-2rem;color:var(--slate);animation:floatA 7s ease-in-out infinite 1.6s}
.about-text h2{margin-bottom:1.4rem}
.about-lead{
  font-family:"Fraunces",serif;font-size:1.12rem;font-style:italic;
  color:var(--slate);line-height:1.65;
  border-left:3px solid var(--orange);padding-left:1.2rem;
  margin-bottom:1.5rem;
}
.about-text p{color:var(--ink2);font-size:.96rem;line-height:1.9;margin-bottom:1.1rem}
.stats-row{display:flex;gap:2.5rem;padding:1.6rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:1.8rem 0}
.stat-box strong{display:block;font-family:"Fraunces",serif;font-size:1.9rem;font-weight:700;color:var(--slate-dk);line-height:1}
.stat-box span{font-size:.73rem;color:var(--ink3);font-weight:500}
.skill-chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.5rem}
.sc{
  background:var(--bg3);border:1.5px solid var(--border);
  padding:.35rem .85rem;border-radius:8px;
  font-size:.74rem;font-weight:600;color:var(--ink2);
  transition:all .3s var(--r);
}
.sc:hover{background:var(--blue-lt);border-color:var(--blue);color:var(--blue)}

/* ── SERVICES ─────────────────────────────── */
#services{background:var(--bg)}
.services-hdr{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.svc-card{
  background:var(--white);border:1.5px solid var(--border);
  border-radius:20px;padding:2rem;
  position:relative;overflow:hidden;
  transition:transform .4s var(--sp),box-shadow .4s var(--r);
}
.svc-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  border-radius:20px 20px 0 0;
}
.svc-card.web::before{background:linear-gradient(90deg,var(--blue),#5ba8e8)}
.svc-card.yt::before{background:linear-gradient(90deg,#e74c3c,#f36)}
.svc-card.bake::before{background:linear-gradient(90deg,var(--orange),#f5c842)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.svc-num{
  position:absolute;top:1.2rem;right:1.5rem;
  font-family:"Fraunces",serif;font-size:2.5rem;font-weight:700;
  opacity:.07;color:var(--slate-dk);line-height:1;
}
.svc-ico{font-size:2rem;margin-bottom:1.1rem}
.svc-card h3{font-family:"Fraunces",serif;font-size:1.25rem;font-weight:700;color:var(--slate-dk);margin-bottom:.7rem}
.svc-card p{font-size:.87rem;color:var(--ink2);line-height:1.8}
.svc-label{
  display:inline-block;margin-top:1.2rem;
  font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink3);
}

/* ── YOUTUBE ──────────────────────────────── */
#work{background:var(--white)}
.yt-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:5rem;align-items:center}
.yt-panel{
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:24px;padding:2.5rem;
}
.yt-branding{display:flex;align-items:center;gap:.9rem;margin-bottom:1.6rem;padding-bottom:1.4rem;border-bottom:1px solid var(--border)}
.yt-icon{
  width:44px;height:44px;border-radius:12px;background:#ff0000;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:#fff;flex-shrink:0;
}
.yt-cname{font-family:"Fraunces",serif;font-weight:700;font-size:.95rem;color:var(--slate-dk)}
.yt-csub{font-size:.72rem;color:var(--ink3)}
.yt-topics{display:flex;flex-direction:column;gap:.75rem}
.yt-item{
  display:flex;align-items:flex-start;gap:.9rem;
  padding:.85rem 1rem;background:var(--white);
  border:1.5px solid var(--border);border-radius:12px;
  transition:all .3s var(--r);text-decoration:none;color:inherit;
}
.yt-item:hover{border-color:rgba(192,57,43,.3);background:#fff8f8;transform:translateX(4px)}
.yt-item-ico{font-size:1.15rem;flex-shrink:0;margin-top:.05rem}
.yt-item strong{display:block;font-size:.82rem;font-weight:700;color:var(--slate-dk);margin-bottom:.15rem}
.yt-item p{font-size:.76rem;color:var(--ink3);line-height:1.5}
.yt-cta-row{margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--border);display:flex;gap:.8rem;flex-wrap:wrap}
.vid-grid{display:flex;flex-direction:column;gap:1rem}
.vid-card{
  display:flex;gap:1rem;background:var(--bg);
  border:1.5px solid var(--border);border-radius:14px;padding:1rem;
  text-decoration:none;color:inherit;
  transition:all .35s var(--r);align-items:flex-start;
}
.vid-card:hover{border-color:rgba(192,57,43,.25);background:#fff8f8;transform:translateX(5px);box-shadow:var(--shadow-sm)}
.vid-thumb{
  width:110px;flex-shrink:0;aspect-ratio:16/9;
  background-color:var(--bg3);
  background-size:cover;background-position:center;
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.play-btn{
  width:28px;height:28px;background:#ff0000;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;color:#fff;
  transition:transform .3s var(--sp);
}
.vid-card:hover .play-btn{transform:scale(1.15)}
.vid-dur{
  position:absolute;bottom:.3rem;right:.3rem;
  background:rgba(0,0,0,.65);font-size:.6rem;
  color:#fff;padding:.1rem .35rem;border-radius:3px;font-weight:600;
}
.vid-info{}
.vid-cat{font-size:.66rem;font-weight:700;color:#c0392b;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.3rem}
.vid-title{font-size:.82rem;font-weight:600;color:var(--slate-dk);line-height:1.45}
.vid-meta{font-size:.72rem;color:var(--ink3);margin-top:.35rem}

/* ── BAKERY ──────────────────────────────── */
#bakery{
  background:linear-gradient(135deg,#1b0e04 0%,#2a1608 40%,#1e1006 100%);
  color:#fff;position:relative;overflow:hidden;
}
#bakery::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 55% 55% at 80% 30%,rgba(244,122,32,.12),transparent 60%),
    radial-gradient(ellipse 40% 40% at 10% 80%,rgba(244,122,32,.07),transparent 50%);
  pointer-events:none;
}
.bakery-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:center}
.bakery-card{
  background:rgba(255,255,255,.07);
  border:1.5px solid rgba(255,255,255,.12);
  border-radius:24px;padding:2.5rem;text-align:center;
  backdrop-filter:blur(12px);
}
.bakery-emoji{font-size:4.5rem;text-align:center;display:block;margin-bottom:1rem;animation:floatA 4s ease-in-out infinite}
.bakery-name{font-family:"Fraunces",serif;font-size:1.5rem;font-weight:700;text-align:center;color:#f5c842;margin-bottom:.3rem}
.bakery-sub{text-align:center;font-size:.76rem;color:rgba(245,200,66,.45);font-weight:600;letter-spacing:.08em;margin-bottom:2rem}
.b-items{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
.b-item{
  background:rgba(244,122,32,.07);border:1px solid rgba(244,122,32,.15);
  border-radius:12px;padding:.9rem;text-align:center;
  transition:all .3s var(--r);
}
.b-item:hover{background:rgba(244,122,32,.14);border-color:rgba(244,122,32,.3);transform:translateY(-3px)}
.b-item-ico{font-size:1.5rem;display:block;margin-bottom:.4rem;line-height:1.2}
.b-item-name{font-size:.73rem;font-weight:600;color:rgba(245,200,66,.75)}
.bakery-text .tag{color:rgba(245,200,66,.7)}
.bakery-text .sec-h{color:#fff}
.bakery-text .sec-h em{color:#f5c842}
.bakery-text p{color:rgba(255,255,255,.6);font-size:.96rem;line-height:1.9;margin-bottom:1.1rem}
.bakery-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  background:#f5c842;color:#1b0e04;
  border:none;
  padding:.85rem 2rem;border-radius:100px;
  font-size:.85rem;font-weight:700;text-decoration:none;margin-top:1rem;
  box-shadow:0 4px 18px rgba(245,200,66,.35);
  transition:all .35s var(--r);
}
.bakery-cta:hover{background:#f9d84a;transform:translateY(-2px);box-shadow:0 8px 28px rgba(245,200,66,.45)}

/* ── CONTACT ──────────────────────────────── */
#contact{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:start}
.c-methods{display:flex;flex-direction:column;gap:1rem}
.cmethod{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.2rem;border-radius:14px;
  background:var(--bg);border:1.5px solid var(--border);
  text-decoration:none;color:inherit;
  transition:all .3s var(--r);
}
.cmethod:hover{border-color:var(--blue);background:var(--blue-lt);transform:translateX(4px)}
.cm-ico{width:38px;height:38px;background:var(--white);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;border:1.5px solid var(--border)}
.cm-label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);margin-bottom:.1rem}
.cm-val{display:block;font-size:.85rem;font-weight:600;color:var(--slate-dk)}
.cform{
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:20px;padding:2rem;
  display:flex;flex-direction:column;gap:1.2rem;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label{font-size:.76rem;font-weight:700;letter-spacing:.04em;color:var(--ink2)}
.fg input,.fg select,.fg textarea{
  background:var(--white);border:1.5px solid var(--border);
  border-radius:10px;padding:.75rem 1rem;
  font-family:"Plus Jakarta Sans",sans-serif;font-size:.87rem;color:var(--ink);
  transition:border-color .25s,box-shadow .25s;outline:none;width:100%;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,127,212,.12)}
.fg textarea{resize:vertical;min-height:120px}
.form-btn{
  background:var(--orange);color:#fff;
  border:none;border-radius:100px;
  padding:.9rem 2rem;font-family:"Plus Jakarta Sans",sans-serif;
  font-size:.88rem;font-weight:700;cursor:pointer;
  box-shadow:0 4px 18px rgba(244,122,32,.28);
  transition:transform .35s var(--sp),box-shadow .35s;
}
.form-btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(244,122,32,.38)}

/* ── FOOTER ───────────────────────────────── */
footer{
  background:var(--slate-dk);color:rgba(255,255,255,.7);
  padding:2.8rem 5vw;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1.5rem;
}
.foot-logo span{
  font-family:'Fraunces',serif;font-size:1rem;font-weight:700;color:#fff;
}
.foot-dot{color:var(--orange)}
.foot-np{color:#7ab3e0}
.foot-links{display:flex;gap:2rem;list-style:none;flex-wrap:wrap}
.foot-links a{font-size:.78rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color .25s}
.foot-links a:hover{color:#fff}
.foot-copy{font-size:.74rem;color:rgba(255,255,255,.35)}

/* ══════════════════════════════════════════════════
   RESPONSIVE — TABLET (≤900px)
══════════════════════════════════════════════════ */
@media(max-width:900px){
  .sec{padding:4rem 5vw}

  /* Hero */
  .hero-inner{grid-template-columns:1fr;gap:2rem;text-align:center}
  .hero-cards{display:none}
  .hero-h1{font-size:clamp(2rem,7vw,3rem)}
  .hero-btns{justify-content:center}
  .hero-roles{justify-content:center}
  .hero-chips{justify-content:center}

  /* About */
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .portrait{max-width:280px;margin:0 auto}
  .fc1,.fc2,.fc3{display:none}          /* hide floating chips — they overlap */
  .avail-badge{bottom:-.6rem}
  .stats-row{gap:1.5rem;padding:1.2rem 0;flex-wrap:wrap}
  .about-text h2{margin-bottom:1rem}

  /* Services */
  .services-hdr{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:2rem}
  .svc-grid{grid-template-columns:1fr}

  /* YouTube */
  .yt-wrap{grid-template-columns:1fr;gap:2.5rem}
  .vid-grid{flex-direction:column}
  .vid-card{flex-direction:row}          /* keep horizontal even on tablet */

  /* Bakery */
  .bakery-grid{grid-template-columns:1fr;gap:2.5rem}
  .bakery-visual{display:flex;justify-content:center}
  .bakery-card{max-width:380px;width:100%}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}

  /* h2 size */
  h2.sec-h{font-size:clamp(1.7rem,5vw,2.4rem)}
}

/* ══════════════════════════════════════════════════
   RESPONSIVE — MOBILE (≤768px)
══════════════════════════════════════════════════ */
@media(max-width:768px){
  /* Nav */
  .nav-links{display:none}
  .hb{display:flex}

  /* Services header sub */
  .services-hdr{flex-direction:column;align-items:flex-start}
}

/* ══════════════════════════════════════════════════
   RESPONSIVE — SMALL MOBILE (≤540px)
══════════════════════════════════════════════════ */
@media(max-width:540px){
  .sec{padding:3rem 4vw}

  /* Hero */
  .hero-h1{font-size:clamp(1.8rem,8.5vw,2.6rem);line-height:1.15}
  .hero-desc{font-size:.88rem}
  .hero-btns{flex-direction:column;align-items:center;gap:.7rem}
  .btn-primary,.btn-outline{width:100%;justify-content:center}
  .hero-chips{gap:.4rem}
  .chip{font-size:.68rem;padding:.28rem .7rem}

  /* About */
  .stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:1rem 0}
  .stat-box strong{font-size:1.5rem}
  .skill-chips{gap:.4rem}
  .sc{font-size:.7rem;padding:.3rem .7rem}

  /* Services */
  .svc-grid{grid-template-columns:1fr}
  .svc-card{padding:1.5rem}

  /* YouTube — stack thumbnail on top on tiny screens */
  .vid-card{flex-direction:column}
  .vid-thumb{width:100% !important;aspect-ratio:16/9 !important}
  .yt-panel{padding:1.5rem}
  .yt-wrap{gap:2rem}
  section#work .vid-thumb{width:100% !important}

  /* Bakery */
  .b-items{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .b-item{padding:.7rem .4rem}
  .bakery-card{padding:1.8rem 1.2rem}
  .bakery-emoji{font-size:3.5rem !important}

  /* Contact */
  .form-row{grid-template-columns:1fr}
  .cform{padding:0}

  /* Heading sizes */
  h2.sec-h{font-size:clamp(1.55rem,7vw,2rem)}

  /* Footer — stack vertically */
  footer,#amaresh-footer{
    flex-direction:column !important;
    text-align:center !important;
    align-items:center !important;
    justify-content:center !important;
    gap:1.2rem !important;
    padding:2rem 5vw !important;
  }
  .foot-links{
    justify-content:center !important;
    gap:.6rem 1.2rem !important;
    flex-wrap:wrap !important;
  }
  .foot-copy{font-size:.7rem !important}
}

/* ══════════════════════════════════════════════════
   WORDPRESS CONFLICT GUARDS
   Prevent WP core / plugin CSS from breaking design
══════════════════════════════════════════════════ */

/* Custom logo image sizing */
.nav-logo-img { display:flex; align-items:center; }
.nav-logo-img a { display:flex; align-items:center; text-decoration:none; }
.nav-logo-img img,
.nav-logo-img .custom-logo { height:36px; width:auto; display:block; }

/* ── BAKERY — force dark background (WP can't override) ── */
section#bakery,
#bakery {
  background: linear-gradient(135deg,#1b0e04 0%,#2a1608 40%,#1e1006 100%) !important;
  color: #fff !important;
}
#bakery .sec-h   { color: #fff !important; }
#bakery .sec-h em { color: #f5c842 !important; }
#bakery p        { color: rgba(255,255,255,.65) !important; }
#bakery .tag     { color: rgba(245,200,66,.7) !important; }

/* ── FOOTER — force dark background, horizontal layout ── */
footer#amaresh-footer,
#amaresh-footer {
  background: var(--slate-dk) !important;
  padding: 2.8rem 5vw !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 1.5rem !important;
  text-align: left !important;
  border: none !important;
  margin: 0 !important;
}
#amaresh-footer .foot-logo {
  display: flex;
  align-items: center;
}
#amaresh-footer .foot-logo span {
  font-family: 'Fraunces', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #fff !important;
}
#amaresh-footer .foot-logo img {
  height: 32px;
  width: auto;
  filter: brightness(0) invert(1);
  margin: 0;
}
#amaresh-footer .foot-logo .custom-logo-link { display:inline-flex; }
/* Higher specificity to beat .foot-logo span rule */
#amaresh-footer .foot-logo span.foot-dot { color: #f47a20 !important; }
#amaresh-footer .foot-logo span.foot-np  { color: #7ab3e0 !important; }
#amaresh-footer .foot-links {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 2rem !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  justify-content: flex-start !important;
}
#amaresh-footer .foot-links a {
  font-size: .78rem !important;
  color: rgba(255,255,255,.5) !important;
  text-decoration: none !important;
  transition: color .25s !important;
}
#amaresh-footer .foot-links a:hover { color: #fff !important; }
#amaresh-footer .foot-copy {
  font-size: .74rem !important;
  color: rgba(255,255,255,.35) !important;
  margin: 0 !important;
}

/* ── YOUTUBE SECTION — force white background ── */
section#work { background: #ffffff !important; }

/* ── YOUTUBE — force correct video layout (vertical list, not grid) ── */
section#work .vid-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 1rem !important;
}
section#work .vid-card {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 1rem !important;
  padding: 1rem !important;
  background: var(--bg) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 14px !important;
  overflow: visible !important;
}
section#work .vid-thumb {
  width: 110px !important;
  flex-shrink: 0 !important;
  height: auto !important;
  aspect-ratio: 16/9 !important;
  border-radius: 8px !important;
  background-color: var(--bg3) !important;  /* fallback colour only — inline style sets bg-image */
  background-size: cover !important;
  background-position: center !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  overflow: hidden !important;
}
section#work .play-btn {
  width: 28px !important;
  height: 28px !important;
  background: #ff0000 !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: .7rem !important;
  color: #fff !important;
  backdrop-filter: none !important;
}
section#work .vid-info {
  padding: 0 !important;
  flex: 1 !important;
}
section#work .vid-cat {
  color: #c0392b !important;
  font-size: .66rem !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  margin-bottom: .3rem !important;
}
section#work .vid-title {
  font-size: .82rem !important;
  font-weight: 600 !important;
  color: var(--slate-dk) !important;
  line-height: 1.45 !important;
}
section#work .vid-meta {
  font-size: .72rem !important;
  color: var(--ink3) !important;
  margin-top: .35rem !important;
}
/* ── YouTube panel: force topic items to have card borders ── */
section#work .yt-item {
  background: var(--white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 12px !important;
  padding: .85rem 1rem !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: .9rem !important;
}
/* ── yt-wrap column proportions ── */
section#work .yt-wrap {
  grid-template-columns: 1.1fr 1fr !important;
}

/* ── Remove WP admin bar offset on nav ── */
.admin-bar #nav { top: 32px; }
@media screen and (max-width:782px) { .admin-bar #nav { top: 46px; } }

/* ── WP paragraph margin surgical reset ──────────────────────────────────────
   Problem: ID selectors like #about p {margin:0} beat class selectors like
   .about-text p {margin:1.1rem} because IDs have higher specificity (0101 > 0011).
   Fix: Only reset known WP-injected wrappers, not all paragraphs.
   Content paragraphs get their spacing from their own class rules below.
─────────────────────────────────────────────────────────────────────────── */

/* WP injects .wp-caption p, figure p — reset those only */
.wp-caption p, figure p, figcaption { margin: 0; font-size: .8rem; color: var(--ink3); }

/* Ensure all named text elements have correct paragraph spacing */
.about-text p,
.about-text div p   { color:var(--ink2);font-size:.96rem;line-height:1.9;margin-bottom:1.1rem !important; }
.about-lead         { margin-bottom:1.5rem !important; }
.sec-sub            { margin-bottom:1rem !important; }
.svc-card p         { font-size:.87rem;color:var(--ink2);line-height:1.8;margin-bottom:.8rem !important; }
.yt-item p          { font-size:.76rem;color:var(--ink3);line-height:1.5;margin-bottom:0 !important; }
.c-intro p,
#contact .c-intro p { color:var(--ink2);font-size:.96rem;line-height:1.9;margin-bottom:1.1rem !important; }
.hero-desc          { margin-bottom:1.5rem !important; }

/* ── Bakery items emoji (b-item-ico) — ensure emojis show ── */
.b-item-ico {
  font-size: 1.5rem !important;
  display: block !important;
  margin-bottom: .4rem !important;
  line-height: 1.2 !important;
}
/* ── Bakery b-item orange tint (match HTML) ── */
#bakery .b-item {
  background: rgba(244,122,32,.07) !important;
  border: 1px solid rgba(244,122,32,.15) !important;
}
#bakery .b-item:hover {
  background: rgba(244,122,32,.14) !important;
  border-color: rgba(244,122,32,.3) !important;
}
#bakery .b-item-name { color: rgba(245,200,66,.75) !important; }
/* ── Bakery emoji size ── */
#bakery .bakery-emoji { font-size: 4.5rem !important; }
/* ── Bakery CTA button — bright yellow ── */
#bakery .bakery-cta {
  background: #f5c842 !important;
  color: #1b0e04 !important;
  border: none !important;
  box-shadow: 0 4px 18px rgba(245,200,66,.35) !important;
}
#bakery .bakery-cta:hover {
  background: #f9d84a !important;
  transform: translateY(-2px) !important;
}
/* ── Bakery paragraph spacing ── */
#bakery .bakery-text p,
#bakery .bakery-para,
#bakery .bakery-para p { margin-bottom: 1.1rem !important; color: rgba(255,255,255,.6) !important; font-size: .96rem !important; line-height: 1.9 !important; }

/* ── WP figure/image resets ── */
figure { margin: 0; }
img { max-width: 100%; height: auto; }

/* ══════════════════════════════════════════════════
   MOBILE OVERRIDES — must come LAST in file
   Conflict guards above use !important so they beat
   normal media queries. These rules come after ALL
   conflict guards so they win via cascade order.
══════════════════════════════════════════════════ */

@media(max-width:900px){
  /* YouTube: stack panel above videos */
  section#work .yt-wrap { grid-template-columns: 1fr !important; gap: 2rem !important; }
  section#work .vid-grid { flex-direction: column !important; }
  /* Bakery: single column */
  section#bakery .bakery-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
  section#bakery .bakery-visual { display: flex !important; justify-content: center !important; }
  section#bakery .bakery-card { max-width: 380px !important; width: 100% !important; }
  /* Contact: single column */
  #contact .contact-grid { grid-template-columns: 1fr !important; }
  /* Services: single column */
  #services .svc-grid { grid-template-columns: 1fr !important; }
  /* About: single column */
  #about .about-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
  #about .portrait { max-width: 260px !important; margin: 0 auto !important; }
  #about .fc1, #about .fc2, #about .fc3 { display: none !important; }
}

@media(max-width:540px){
  /* Section padding */
  section.sec { padding: 2.8rem 4vw !important; }

  /* Hero */
  #home .hero-inner { grid-template-columns: 1fr !important; text-align: center !important; }
  #home .hero-cards { display: none !important; }
  #home .hero-btns { flex-direction: column !important; align-items: center !important; gap: .7rem !important; }
  #home .btn-primary, #home .btn-outline { width: 100% !important; justify-content: center !important; max-width: 280px !important; }

  /* YouTube: vid-card column on small screens */
  section#work .vid-card {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  section#work .vid-thumb {
    width: 100% !important;
    aspect-ratio: 16/9 !important;
    flex-shrink: unset !important;
  }
  section#work .yt-panel { padding: 1.2rem !important; }

  /* Services */
  #services .svc-card { padding: 1.4rem !important; }

  /* Bakery */
  section#bakery .bakery-card { padding: 1.5rem 1rem !important; }
  section#bakery .bakery-emoji { font-size: 3rem !important; }
  section#bakery .b-items { grid-template-columns: repeat(2,1fr) !important; gap: .5rem !important; }

  /* Contact form */
  #contact .form-row { grid-template-columns: 1fr !important; }

  /* Footer: force column stacking — overrides conflict guard !important */
  footer#amaresh-footer,
  #amaresh-footer {
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 2rem 4vw !important;
    gap: 1rem !important;
  }
  #amaresh-footer .foot-links {
    justify-content: center !important;
    gap: .5rem 1rem !important;
    flex-wrap: wrap !important;
  }
  #amaresh-footer .foot-links a { font-size: .73rem !important; }
  #amaresh-footer .foot-copy { font-size: .68rem !important; }
}

/* ══════════════════════════════════════════════════
   PADDING FIX — Hero & Form mobile horizontal padding
   #home has no .sec class so gets no side padding
   .cform padding:0 on mobile removes card padding
══════════════════════════════════════════════════ */
@media(max-width:900px){
  #home { padding-left: 5vw !important; padding-right: 5vw !important; }
  #home .hero-inner { padding-left: 0; padding-right: 0; }
}

@media(max-width:540px){
  /* Hero horizontal padding */
  #home { padding-left: 5vw !important; padding-right: 5vw !important; }

  /* All sections — minimum 16px side padding */
  section.sec { padding-left: max(16px, 4vw) !important; padding-right: max(16px, 4vw) !important; }

  /* Contact form — keep card padding on mobile */
  .cform { padding: 1.2rem !important; border-radius: 14px !important; }
  #contact .form-row { grid-template-columns: 1fr !important; }

  /* Form button full width */
  .form-btn { width: 100% !important; }
}

/* ── Portrait card mobile width fix ── */
@media(max-width:540px){
  #about .portrait { max-width: min(280px, 80vw) !important; }
  #about .portrait-box { border-radius: 18px !important; }
  #about .avail-badge { font-size: .7rem !important; padding: .4rem .9rem !important; }
}
