/* FreeCrochet Ad Flow — main.css */
:root{
  --rose:#C1440E; --rose2:#A33208; --rl:#FAF0EE; --rl2:#F5D5CC;
  --cream:#FAFAFA; --cream2:#F5F0EB;
  --ink:#1A1208; --ink2:#4A3728; --ink3:#9C8B7A;
  --border:#E8DDD8; --white:#fff; --green:#1D9E75;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.7}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* HEADER */
.site-header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.header-in{max-width:1140px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{font-family:var(--serif);font-size:20px;color:var(--ink);display:flex;align-items:center}
.logo em{color:var(--rose);font-style:italic}
.logo sub{font-size:10px;font-weight:700;background:var(--rose);color:#fff;padding:1px 5px;border-radius:4px;margin-left:3px;vertical-align:middle}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{font-size:13px;color:var(--ink2);padding:6px 12px;border-radius:6px;transition:.15s}
.nav-links a:hover{background:var(--rl);color:var(--rose)}
.nav-cta{background:var(--rose)!important;color:#fff!important;font-weight:600!important;border-radius:8px!important}
@media(max-width:640px){.nav-links .hs{display:none}}

/* AD ZONE */
.ad-zone{display:flex;justify-content:center;align-items:center;padding:10px 24px;min-height:100px;background:var(--cream2);border-bottom:1px solid var(--border)}

/* HERO */
.hero-wrap{background:#fff;border-bottom:1px solid var(--border)}
.hero{max-width:1140px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;min-height:400px;align-items:stretch}
.hero-content{padding:52px 48px 52px 0;display:flex;flex-direction:column;justify-content:center}
.hero-pill{display:inline-flex;align-items:center;gap:6px;background:var(--rl);color:var(--rose);font-size:12px;font-weight:600;padding:5px 14px;border-radius:20px;margin-bottom:18px;width:fit-content}
.hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,44px);line-height:1.1;margin-bottom:14px;color:var(--ink)}
.hero-sub{font-size:15px;color:var(--ink3);margin-bottom:28px;line-height:1.7}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap}
.hero-img{overflow:hidden;min-height:360px}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-img-ph{width:100%;height:100%;min-height:360px;background:linear-gradient(135deg,#FAF0EE,#F5D5CC);display:flex;align-items:center;justify-content:center;font-size:100px}
@media(max-width:768px){.hero{grid-template-columns:1fr}.hero-img{display:none}.hero-content{padding:40px 0}}

/* BUTTONS */
.btn-rose{background:var(--rose);color:#fff;padding:12px 26px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;font-family:var(--sans);transition:.18s;display:inline-flex;align-items:center;gap:6px}
.btn-rose:hover{background:var(--rose2);color:#fff;transform:translateY(-1px)}
.btn-outline{border:1.5px solid var(--border);color:var(--ink);padding:11px 22px;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;font-family:var(--sans);transition:.18s;display:inline-flex;align-items:center;gap:6px}
.btn-outline:hover{border-color:var(--rose);color:var(--rose)}

/* SECTIONS */
.section{max-width:1140px;margin:0 auto;padding:48px 24px}
.section-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:10px}
.section-title{font-family:var(--serif);font-size:26px;color:var(--ink);font-weight:400}
.section-sub{font-size:13px;color:var(--ink3);margin-top:4px}
.view-all{font-size:13px;color:var(--rose);font-weight:500}
.view-all:hover{color:var(--rose2)}

/* FILTER TABS */
.filter-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.filter-tab{padding:7px 18px;border-radius:20px;border:1.5px solid var(--border);background:transparent;font-family:var(--sans);font-size:13px;color:var(--ink3);cursor:pointer;transition:.18s}
.filter-tab:hover,.filter-tab.active{background:var(--rose);color:#fff;border-color:var(--rose)}

/* PATTERN GRID */
.patterns-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1024px){.patterns-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.patterns-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.patterns-grid{grid-template-columns:1fr}}

/* PATTERN CARD */
.p-card{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:.2s;display:flex;flex-direction:column;cursor:pointer}
.p-card:hover{box-shadow:0 8px 28px rgba(193,68,14,.12);transform:translateY(-3px);border-color:var(--rl2)}
.p-thumb{height:190px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--cream2)}
.p-thumb img{width:100%;height:100%;object-fit:cover;transition:.3s}
.p-card:hover .p-thumb img{transform:scale(1.05)}
.p-badge{position:absolute;bottom:0;left:0;right:0;background:rgba(193,68,14,.88);color:#fff;font-size:11px;font-weight:700;padding:6px;text-align:center;letter-spacing:.4px}
.p-diff{position:absolute;top:10px;right:10px;font-size:10px;font-weight:600;padding:3px 9px;border-radius:10px}
.p-body{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column}
.p-cat{font-size:11px;color:var(--rose);font-weight:600;text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px}
.p-title{font-family:var(--serif);font-size:15px;line-height:1.3;color:var(--ink);margin-bottom:auto;padding-bottom:10px}
.p-foot{padding-top:10px;border-top:1px solid var(--border)}
.dl-btn{width:100%;background:var(--rose);color:#fff;border:none;padding:10px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:.18s}
.dl-btn:hover{background:var(--rose2)}

/* CATEGORIES */
.cats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
@media(max-width:900px){.cats-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.cats-grid{grid-template-columns:repeat(2,1fr)}}
.cat-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px 12px;transition:.18s;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;cursor:pointer;text-decoration:none}
.cat-card:hover{border-color:var(--rose);background:var(--rl);transform:translateY(-2px)}
.cat-ico{width:46px;height:46px;background:var(--rl);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px}
.cat-name{font-size:13px;font-weight:600;color:var(--ink)}
.cat-cnt{font-size:11px;color:var(--ink3)}

/* NEWSLETTER */
.nl-bar{background:var(--rl);border-top:1px solid var(--rl2);border-bottom:1px solid var(--rl2);padding:28px 24px}
.nl-inner{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.nl-left{display:flex;align-items:center;gap:14px}
.nl-ico{width:46px;height:46px;background:var(--rose);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}
.nl-text h3{font-family:var(--serif);font-size:17px;color:var(--ink);margin-bottom:2px}
.nl-text p{font-size:13px;color:var(--ink3)}
.nl-form{display:flex;gap:8px;flex-wrap:wrap}
.nl-input{padding:11px 16px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--sans);outline:none;background:#fff;min-width:220px}
.nl-input:focus{border-color:var(--rose)}
.nl-btn{background:var(--rose);color:#fff;border:none;padding:11px 22px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--sans)}
.nl-btn:hover{background:var(--rose2)}

/* SPLIT LAYOUT */
.split-layout{max-width:1140px;margin:0 auto;padding:0 24px 48px;display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start}
@media(max-width:900px){.split-layout{grid-template-columns:1fr}}
.sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:80px}
.sb-box{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px}
.sb-box h3{font-family:var(--serif);font-size:16px;margin-bottom:14px;color:var(--ink)}
.pop-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:.5px solid var(--border);text-decoration:none}
.pop-item:last-child{border-bottom:none}
.pop-item:hover .pop-title{color:var(--rose)}
.pop-ico{width:46px;height:46px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--cream2);display:flex;align-items:center;justify-content:center;font-size:20px}
.pop-ico img{width:100%;height:100%;object-fit:cover}
.pop-title{font-size:13px;font-weight:500;color:var(--ink);line-height:1.3}
.pop-sub{font-size:11px;color:var(--ink3);margin-top:2px}

/* FOOTER */
.site-footer{background:#1A1208;color:#9C8B7A;padding:48px 24px 24px}
.footer-grid{max-width:1140px;margin:0 auto 36px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand p{font-size:13px;color:#6B5A4A;margin-top:10px;line-height:1.6;max-width:200px}
.footer-col h4{font-size:12px;font-weight:700;color:#FAF6F0;margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}
.footer-col a{display:block;font-size:13px;color:#9C8B7A;margin-bottom:8px;transition:.15s}
.footer-col a:hover{color:#FAF6F0}
.footer-menu{list-style:none;padding:0;margin:0}
.footer-menu li a{display:block;font-size:13px;color:#9C8B7A;margin-bottom:8px;text-decoration:none;transition:.15s}
.footer-menu li a:hover{color:#FAF6F0}
.footer-bottom{max-width:1140px;margin:0 auto;border-top:1px solid rgba(255,255,255,.08);padding-top:18px;display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#6B5A4A;flex-wrap:wrap;gap:10px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:#9C8B7A;font-size:13px;transition:.18s}
.footer-social a:hover{background:var(--rose);border-color:var(--rose);color:#fff}

/* ═══════════════════════════════════════════
   3-STEP MODAL: Ad → Email → Success
   ═══════════════════════════════════════════ */
@keyframes mdSlide{from{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fcpPulse{0%,100%{opacity:1}50%{opacity:.6}}

.dl-overlay{display:none;position:fixed;inset:0;background:rgba(20,8,4,.82);z-index:9999;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.dl-overlay.open{display:flex}
.modal-box{background:#fff;border-radius:20px;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;animation:mdSlide .28s ease}

/* STEP HEADER */
.step-head{background:var(--rose);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;border-radius:20px 20px 0 0}
.step-head h3{font-family:var(--serif);color:#fff;font-size:17px}
.close-x{background:none;border:none;color:rgba(255,255,255,.8);font-size:26px;cursor:pointer;padding:0;line-height:1}
.close-x:hover{color:#fff}

/* STEPS INDICATOR */
.steps-bar{display:flex;align-items:center;justify-content:center;gap:0;padding:14px 24px 10px;background:var(--rl);border-bottom:1px solid var(--rl2)}
.s-wrap{display:flex;flex-direction:column;align-items:center;gap:4px}
.s-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;transition:.3s}
.s-dot.done{background:var(--green);color:#fff}
.s-dot.current{background:var(--rose);color:#fff}
.s-dot.todo{background:var(--border);color:var(--ink3)}
.s-line{width:48px;height:2px;background:var(--border);transition:.3s;margin-top:-14px}
.s-line.done{background:var(--green)}
.s-lbl{font-size:11px;color:var(--ink3)}

/* STEP 1 — VIDEO AD */
.step-body{padding:20px 24px 24px}
.ad-screen{background:linear-gradient(135deg,#1A1208,#3D2314);border-radius:14px;height:210px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;margin-bottom:14px;position:relative;overflow:hidden}
.ad-screen ins{position:absolute;inset:0;width:100%!important;height:100%!important}
.ad-ph-inner{display:flex;flex-direction:column;align-items:center;gap:10px;color:#C9B09A;position:relative;z-index:1}
.play-ring{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;animation:fcpPulse 2s ease-in-out infinite}
.ad-ph-inner p{font-size:13px}
.ad-ph-inner small{font-size:10px;opacity:.6}
.ad-prog-bar{height:5px;background:rgba(255,255,255,.15);border-radius:3px;margin-bottom:8px;overflow:hidden}
.ad-prog-fill{height:100%;background:var(--rose);border-radius:3px;transition:width .1s linear;width:0%}
.skip-row{display:flex;align-items:center;justify-content:space-between}
.skip-txt{font-size:12px;color:var(--ink3)}
.skip-btn{background:var(--rose);color:#fff;border:none;padding:8px 20px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:.18s}
.skip-btn:hover:not(:disabled){background:var(--rose2)}
.skip-btn:disabled{opacity:.4;cursor:not-allowed}
.ad-support{font-size:13px;color:var(--ink3);text-align:center;line-height:1.5;margin-top:14px}

/* STEP 2 — EMAIL */
.pat-prev{display:flex;align-items:center;gap:14px;background:var(--rl);border:1px solid var(--rl2);border-radius:12px;padding:14px;margin-bottom:20px}
.pat-prev-thumb{width:52px;height:52px;border-radius:8px;background:var(--rl2);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;overflow:hidden}
.pat-prev-thumb img{width:100%;height:100%;object-fit:cover}
.pat-prev-name{font-family:var(--serif);font-size:15px;color:var(--ink);margin-bottom:2px}
.pat-prev-sub{font-size:12px;color:var(--ink3)}
.f-group{margin-bottom:14px}
.f-lbl{display:block;font-size:11px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.f-in{width:100%;padding:12px 15px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-family:var(--sans);outline:none;transition:.2s}
.f-in:focus{border-color:var(--rose)}
.f-in.err{border-color:var(--rose);background:#fff8f7}
.f-err-msg{font-size:12px;color:var(--rose);margin-top:5px;display:none}
.consent-row{display:flex;gap:9px;align-items:flex-start;margin-bottom:14px;font-size:12px;color:var(--ink3);line-height:1.5}
.consent-row input{margin-top:2px;accent-color:var(--rose);width:14px;height:14px;flex-shrink:0}
.privacy-note{font-size:11px;color:#bbb;text-align:center;margin-bottom:16px}
.submit-btn{width:100%;background:var(--rose);color:#fff;border:none;padding:14px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;font-family:var(--sans);display:flex;align-items:center;justify-content:center;gap:8px;transition:.18s}
.submit-btn:hover:not(:disabled){background:var(--rose2)}
.submit-btn:disabled{opacity:.5;cursor:not-allowed}
.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:none}

/* STEP 3 — SUCCESS */
.success-body{padding:32px 24px;text-align:center}
.success-icon{width:72px;height:72px;background:#EDF7EE;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 16px;border:2px solid #C8E6C9}
.success-title{font-family:var(--serif);font-size:22px;color:var(--ink);margin-bottom:10px}
.success-sub{font-size:14px;color:var(--ink3);line-height:1.6;margin-bottom:18px}
.email-confirm{background:var(--rl);border-radius:10px;padding:13px 16px;display:flex;align-items:center;gap:12px;margin-bottom:16px;border:1px solid var(--rl2);text-align:left}
.email-confirm strong{display:block;color:var(--ink);font-size:14px;margin-bottom:2px}
.email-confirm span{font-size:12px;color:var(--ink3)}
.direct-dl{display:block;background:var(--rose);color:#fff;padding:12px;border-radius:10px;font-weight:700;font-size:14px;text-align:center;margin-bottom:10px;transition:.18s}
.direct-dl:hover{background:var(--rose2);color:#fff}
.browse-more-btn{width:100%;background:transparent;border:1.5px solid var(--border);color:var(--ink2);padding:11px;border-radius:10px;font-size:14px;cursor:pointer;font-family:var(--sans);transition:.18s}
.browse-more-btn:hover{background:var(--cream2)}

/* ═══ MOBILE IMPROVEMENTS ═══ */

/* Modal full-screen on small phones */
@media(max-width:480px){
  .dl-overlay{padding:0!important;align-items:flex-end!important}
  .modal-box{border-radius:20px 20px 0 0!important;max-height:95vh!important}
  .step-head{padding:16px 18px!important}
  .step-body{padding:16px 18px 18px!important}
  .success-body{padding:24px 18px!important}
  .steps-bar{padding:12px 14px 8px!important;gap:0!important}
  .s-line{width:28px!important}
  .s-dot{width:26px!important;height:26px!important;font-size:12px!important}
  .s-lbl{font-size:10px!important}
  .ad-screen{height:160px!important}
  .f-in{font-size:16px!important;padding:11px 13px!important} /* no iOS zoom */
  .submit-btn{font-size:15px!important;padding:14px!important}
  .pat-prev{padding:12px!important}
  .pat-prev-thumb{width:44px!important;height:44px!important;font-size:20px!important}
  .pat-prev-name{font-size:14px!important}
}

/* Navigation on mobile */
@media(max-width:640px){
  .header-in{padding:0 16px!important}
  .logo{font-size:17px!important}
}

/* Hero section mobile */
@media(max-width:480px){
  .hero-content{padding:32px 0!important}
  .hero h1{font-size:26px!important}
  .hero-sub{font-size:14px!important}
  .btn-rose,.btn-outline{padding:11px 20px!important;font-size:13px!important}
}

/* Pattern cards mobile */
@media(max-width:480px){
  .section{padding:32px 16px!important}
  .filter-tabs{gap:6px!important}
  .filter-tab{padding:6px 14px!important;font-size:12px!important}
  .p-thumb{height:160px!important}
  .p-body{padding:12px 13px 14px!important}
  .p-title{font-size:14px!important}
  .dl-btn{padding:9px!important;font-size:12px!important}
}

/* Categories mobile */
@media(max-width:360px){
  .cats-grid{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}
  .cat-card{padding:14px 8px!important}
  .cat-ico{width:38px!important;height:38px!important;font-size:17px!important}
  .cat-name{font-size:12px!important}
}

/* Newsletter bar mobile */
@media(max-width:600px){
  .nl-inner{flex-direction:column!important;gap:16px!important}
  .nl-left{gap:10px!important}
  .nl-form{width:100%!important}
  .nl-input{min-width:unset!important;width:100%!important}
  .nl-btn{width:100%!important}
}

/* Split layout mobile */
@media(max-width:768px){
  .split-layout{padding:0 16px 32px!important}
}

/* Footer mobile */
@media(max-width:480px){
  .site-footer{padding:32px 16px 20px!important}
  .footer-bottom{flex-direction:column!important;text-align:center!important;gap:12px!important}
}

/* Touch improvements */
.dl-btn,.btn-rose,.btn-outline,.skip-btn,.submit-btn,.nl-btn{
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}

/* ── ARCHIVE SEARCH FIX ── */
.arch-search{display:flex;gap:0;margin-bottom:24px;position:relative!important}
.arch-search input{flex:1;padding:12px 52px 12px 16px!important;border:1.5px solid #E8DDD8;border-radius:10px!important;font-size:14px;font-family:'Inter',sans-serif;outline:none;width:100%;box-sizing:border-box}
.arch-search input:focus{border-color:#C1440E}
.arch-search button{position:absolute!important;right:0!important;top:0!important;bottom:0!important;background:#C1440E;color:#fff;border:none;padding:0 16px!important;border-radius:0 10px 10px 0!important;font-size:16px;cursor:pointer}
.arch-search button:hover{background:#A33208}

/* ── CARD CURSOR FIX ── */
.p-card a{cursor:pointer}
.p-card .p-title{color:#1A1208}
.p-card a:hover .p-title{color:#C1440E}


/* === FINAL FIX: animated step 1 / 2 / 3 indicator === */
.s-dot{
  transition:background .25s ease,color .25s ease,transform .25s ease,box-shadow .25s ease !important;
}
.s-line{
  transition:background .25s ease,opacity .25s ease !important;
}
.s-dot.current{
  background:#C1440E !important;
  color:#fff !important;
  transform:scale(1.08) !important;
  box-shadow:0 7px 18px rgba(193,68,14,.28) !important;
}
.s-dot.done{
  background:#C1440E !important;
  color:#fff !important;
  transform:scale(1) !important;
  box-shadow:none !important;
}
.s-dot.todo{
  background:#E8DDD8 !important;
  color:#9C8B7A !important;
  transform:scale(1) !important;
  box-shadow:none !important;
}
.s-line.done{
  background:#C1440E !important;
}
