/* ═══════════════════════════════════════════════
   CraftedDocs — app.css v1.0
   Design system: Amber + Teal, Bricolage Grotesque
═══════════════════════════════════════════════ */
:root {
  --amber:        #D97706; --amber-dark: #92400E; --amber-light: #FEF3C7; --amber-mid: #FDE68A;
  --teal:         #0D9488; --teal-dark:  #134E4A; --teal-light:  #CCFBF1;
  --ink:          #0F1117; --ink-2: #1E2130;
  --muted:        #6B7280; --subtle: #9CA3AF;
  --border:       #E5E7EB; --surface: #F9FAFB; --surface-2: #F3F4F6;
  --white:        #FFFFFF; --danger: #E11D48; --danger-light: #FFE4E6;
  --font-heading: 'Bricolage Grotesque', sans-serif;
  --font-body:    'Lato', sans-serif;
  --font-mono:    'JetBrains Mono', monospace;
  --radius:       12px; --radius-sm: 8px; --radius-lg: 18px; --radius-full: 9999px;
  --shadow:       0 4px 12px rgba(0,0,0,.08); --shadow-lg: 0 14px 44px rgba(0,0,0,.11);
  --header-h:     64px; --t: .18s ease;
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; }
body { font-family:var(--font-body); color:var(--ink); background:#fff; line-height:1.65; -webkit-font-smoothing:antialiased; }
img  { max-width:100%; height:auto; display:block; }
a    { color:var(--amber); text-decoration:none; transition:color var(--t); }
a:hover { color:var(--amber-dark); }
ul,ol { list-style:none; }
button { font-family:var(--font-body); cursor:pointer; }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-heading); font-weight:700; line-height:1.15; color:var(--ink); }

/* ── Layout ─────────────────────────────────── */
.cd-container    { max-width:1200px; margin:0 auto; padding:0 24px; }
.cd-container-sm { max-width:820px;  margin:0 auto; padding:0 24px; }
.cd-section      { padding:72px 0; }
.cd-section-surface { background:var(--surface); }

/* ── Typography ─────────────────────────────── */
.cd-h1     { font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:800; letter-spacing:-.02em; }
.cd-h2     { font-size:clamp(1.4rem,2.5vw,2rem);   font-weight:700; letter-spacing:-.01em; }
.cd-h3     { font-size:1.2rem; font-weight:700; }
.cd-eyebrow{ font-family:var(--font-heading); font-size:.8125rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--amber); margin-bottom:6px; }
.cd-muted  { color:var(--muted); }
.cd-mono   { font-family:var(--font-mono); }

/* ── Buttons ────────────────────────────────── */
.cd-btn { display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:11px 24px; border-radius:var(--radius); font-family:var(--font-heading); font-size:.9rem; font-weight:700; border:2.5px solid transparent; cursor:pointer; text-decoration:none; transition:all var(--t); line-height:1; white-space:nowrap; }
.cd-btn:focus-visible { outline:3px solid var(--amber); outline-offset:2px; }
.cd-btn:disabled { opacity:.5; pointer-events:none; }
.cd-btn-primary { background:var(--amber); color:#fff; border-color:var(--amber); }
.cd-btn-primary:hover { background:var(--amber-dark); border-color:var(--amber-dark); color:#fff; transform:translateY(-1px); box-shadow:0 6px 20px rgba(217,119,6,.35); }
.cd-btn-teal    { background:var(--teal); color:#fff; border-color:var(--teal); }
.cd-btn-teal:hover { background:var(--teal-dark); color:#fff; }
.cd-btn-outline { background:transparent; color:var(--ink); border-color:var(--border); }
.cd-btn-outline:hover { background:var(--surface); border-color:var(--muted); color:var(--ink); }
.cd-btn-ghost   { background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.25); }
.cd-btn-ghost:hover { background:rgba(255,255,255,.2); color:#fff; }
.cd-btn-danger  { background:var(--danger); color:#fff; border-color:var(--danger); }
.cd-btn-danger:hover { background:#BE123C; color:#fff; }
.cd-btn-sm  { padding:7px 16px; font-size:.8125rem; }
.cd-btn-lg  { padding:15px 32px; font-size:1.05rem; }
.cd-btn-full { width:100%; }
.cd-btn-link { background:none; border:none; color:var(--amber); padding:0; font-size:inherit; }

/* ── Tags / Badges ──────────────────────────── */
.cd-tag { display:inline-flex; align-items:center; gap:4px; padding:3px 10px; border-radius:var(--radius-full); font-family:var(--font-heading); font-size:.75rem; font-weight:700; }
.cd-tag-amber    { background:var(--amber-light); color:var(--amber-dark); }
.cd-tag-teal     { background:var(--teal-light);  color:var(--teal-dark); }
.cd-tag-slate    { background:var(--surface-2);   color:var(--muted);      border:1px solid var(--border); }
.cd-tag-pending  { background:#FEF3C7; color:#92400E; }
.cd-tag-approved { background:var(--teal-light);  color:var(--teal-dark); }
.cd-tag-featured { background:#FDE68A; color:#78350F; }
.cd-tag-rejected { background:var(--danger-light); color:#9F1239; }

/* ── Forms ──────────────────────────────────── */
.cd-field       { margin-bottom:18px; }
.cd-field label { display:flex; align-items:center; justify-content:space-between; font-family:var(--font-heading); font-size:.8125rem; font-weight:700; color:var(--muted); margin-bottom:5px; letter-spacing:.03em; text-transform:uppercase; }
.cd-req         { color:var(--danger); }
.cd-field-hint  { font-family:var(--font-body); font-size:.8rem; font-weight:400; color:var(--subtle); letter-spacing:0; text-transform:none; }
.cd-input       { width:100%; height:44px; padding:0 14px; border:2px solid var(--border); border-radius:var(--radius-sm); font-size:.9375rem; font-family:var(--font-body); background:var(--surface); color:var(--ink); outline:none; transition:border-color var(--t),box-shadow var(--t); }
.cd-input:focus { border-color:var(--amber); background:#fff; box-shadow:0 0 0 3px var(--amber-light); }
.cd-input:hover:not(:focus) { border-color:#D1D5DB; }
textarea.cd-input { height:auto; padding:12px 14px; resize:vertical; min-height:96px; }
select.cd-input  { cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M2 4l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:36px; }
.cd-input-sm    { height:36px; font-size:.875rem; }
.cd-field-row   { display:grid; grid-template-columns:1fr 1fr;     gap:16px; }
.cd-field-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; }
.cd-input-group { position:relative; }
.cd-input-group .cd-input-prefix { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--muted); pointer-events:none; }
.cd-input-group .cd-input { padding-left:32px; }
.cd-checkbox-wrap { display:flex; align-items:center; gap:10px; cursor:pointer; font-size:.9rem; }
.cd-checkbox-wrap input[type=checkbox] { width:18px; height:18px; accent-color:var(--amber); flex-shrink:0; cursor:pointer; }
.cd-upload-zone { position:relative; border:2.5px dashed var(--border); border-radius:var(--radius-lg); padding:36px 20px; text-align:center; cursor:pointer; transition:all var(--t); background:var(--surface); }
.cd-upload-zone:hover,.cd-upload-zone.drag { border-color:var(--amber); background:var(--amber-light); }
.cd-file-input { position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:pointer; }
.cd-upload-icon  { font-size:40px; margin-bottom:10px; }
.cd-upload-title { font-family:var(--font-heading); font-weight:700; margin-bottom:4px; }
.cd-upload-hint  { font-size:.8125rem; color:var(--subtle); }
.cd-upload-zone-sm { padding:20px; }
.cd-form-section-title { font-size:1rem; font-weight:800; margin-bottom:18px; padding-bottom:10px; border-bottom:2px solid var(--border); }
.cd-card-flat   { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:24px; }

/* ── Notices ────────────────────────────────── */
.cd-notice { display:flex; gap:10px; padding:13px 16px; border-radius:var(--radius-sm); font-size:.9rem; margin-bottom:var(--gap,16px); border:1.5px solid transparent; }
.cd-notice-info    { background:#EFF6FF; color:#1E40AF; border-color:#BFDBFE; }
.cd-notice-success { background:var(--teal-light);   color:var(--teal-dark);  border-color:#99F6E4; }
.cd-notice-error   { background:var(--danger-light);  color:var(--danger);    border-color:#FECDD3; }
.cd-notice-warning { background:var(--amber-light);   color:var(--amber-dark); border-color:var(--amber-mid); }

/* ── Topbar ─────────────────────────────────── */
#cd-topbar { background:var(--ink-2); color:rgba(255,255,255,.75); font-size:.8125rem; padding:8px 24px; text-align:center; position:relative; z-index:100; }
#cd-topbar a { color:var(--amber-mid); }
#cd-topbar a:hover { color:#fff; }
#cd-topbar-close { position:absolute; right:16px; top:50%; transform:translateY(-50%); background:none; border:none; color:rgba(255,255,255,.4); font-size:16px; cursor:pointer; padding:4px; }
#cd-topbar-close:hover { color:#fff; }

/* ── Header ─────────────────────────────────── */
#cd-header { position:sticky; top:0; z-index:90; background:rgba(255,255,255,.97); backdrop-filter:blur(16px); border-bottom:1.5px solid var(--border); transition:box-shadow var(--t); }
#cd-header.scrolled { box-shadow:var(--shadow-lg); border-bottom-color:transparent; }
.cd-nav { display:flex; align-items:center; gap:12px; height:var(--header-h); }
.cd-logo { display:flex; align-items:center; gap:9px; font-family:var(--font-heading); font-size:1.4rem; font-weight:800; color:var(--ink); text-decoration:none; flex-shrink:0; letter-spacing:-.02em; }
.cd-logo:hover { color:var(--amber-dark); }
.cd-logo-icon { width:34px; height:34px; background:var(--amber); border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:17px; transition:transform var(--t); flex-shrink:0; }
.cd-logo:hover .cd-logo-icon { transform:rotate(-5deg) scale(1.06); }
.cd-logo em { font-style:normal; color:var(--amber); }
.cd-nav-search { flex:1; max-width:420px; position:relative; }
.cd-nav-search svg { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--subtle); pointer-events:none; }
.cd-nav-search input { width:100%; height:40px; padding:0 14px 0 40px; border:2px solid var(--border); border-radius:var(--radius-full); font-size:.875rem; background:var(--surface); outline:none; transition:all var(--t); }
.cd-nav-search input:focus { border-color:var(--amber); background:#fff; box-shadow:0 0 0 3px var(--amber-light); }
.cd-nav-links { display:flex; gap:2px; }
.cd-nav-link { padding:8px 12px; border-radius:var(--radius-sm); font-family:var(--font-heading); font-size:.875rem; font-weight:700; color:var(--muted); transition:all var(--t); }
.cd-nav-link:hover,.cd-nav-link.active { color:var(--ink); background:var(--surface); }
.cd-nav-actions { display:flex; align-items:center; gap:8px; margin-left:auto; flex-shrink:0; }
.cd-cart-btn { position:relative; width:40px; height:40px; border-radius:var(--radius-sm); border:2px solid var(--border); background:#fff; display:flex; align-items:center; justify-content:center; transition:all var(--t); color:var(--ink); }
.cd-cart-btn:hover { border-color:var(--amber); background:var(--amber-light); color:var(--amber-dark); }
.cd-cart-count { position:absolute; top:-5px; right:-5px; background:var(--danger); color:#fff; font-family:var(--font-heading); font-size:.6rem; font-weight:700; border-radius:var(--radius-full); min-width:16px; height:16px; padding:0 4px; display:flex; align-items:center; justify-content:center; border:2px solid #fff; }
.cd-cart-count[data-n="0"],.cd-cart-count:empty { display:none; }
.cd-user-wrap { position:relative; }
.cd-user-btn  { width:36px; height:36px; border-radius:50%; background:var(--amber-light); color:var(--amber-dark); border:2px solid var(--amber-mid); font-family:var(--font-heading); font-weight:800; font-size:.875rem; cursor:pointer; transition:all var(--t); }
.cd-user-btn:hover { background:var(--amber-mid); }
.cd-user-dropdown { display:none; position:absolute; top:calc(100%+8px); right:0; background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); min-width:210px; padding:6px; z-index:100; }
.cd-user-dropdown.open { display:block; }
.cd-dropdown-user-info { padding:10px 12px 8px; border-bottom:1.5px solid var(--border); margin-bottom:4px; }
.cd-dropdown-user-info strong { display:block; font-size:.9rem; color:var(--ink); }
.cd-dropdown-user-info span   { display:block; font-size:.8rem; color:var(--subtle); }
.cd-dropdown-item { display:flex; align-items:center; gap:9px; padding:9px 12px; border-radius:var(--radius-sm); font-size:.875rem; color:var(--muted); transition:all var(--t); }
.cd-dropdown-item:hover { background:var(--surface); color:var(--ink); }
.cd-dropdown-divider { border:none; border-top:1.5px solid var(--border); margin:4px 0; }
.cd-dropdown-logout:hover { background:var(--danger-light); color:var(--danger); }
.cd-burger { display:none; flex-direction:column; gap:5px; justify-content:center; width:40px; height:40px; border:2px solid var(--border); background:transparent; border-radius:var(--radius-sm); padding:9px; }
.cd-burger span { display:block; height:2px; background:var(--ink); border-radius:2px; transition:all var(--t); }
.cd-burger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.cd-burger.open span:nth-child(2) { opacity:0; }
.cd-burger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
.cd-drawer { position:fixed; top:0; left:0; right:0; bottom:0; background:#fff; z-index:95; padding:80px 20px 24px; display:flex; flex-direction:column; gap:4px; transform:translateX(-100%); transition:transform .3s ease; overflow-y:auto; }
.cd-drawer.open { transform:none; }
.cd-drawer-top { position:fixed; top:0; left:0; right:0; display:flex; align-items:center; justify-content:space-between; padding:14px 20px; background:#fff; border-bottom:1.5px solid var(--border); }
#cd-drawer-close { background:none; border:none; font-size:22px; color:var(--muted); cursor:pointer; }
.cd-drawer-link { display:flex; align-items:center; gap:12px; padding:13px 16px; border-radius:var(--radius-sm); font-family:var(--font-heading); font-weight:700; color:var(--ink); border-bottom:1px solid var(--border); }
.cd-drawer-link:hover { background:var(--amber-light); color:var(--amber-dark); border-bottom-color:transparent; }
.cd-drawer-cta { background:var(--amber); color:#fff; border-bottom-color:var(--amber); margin-top:8px; }
.cd-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:94; backdrop-filter:blur(4px); }
.cd-overlay.show { display:block; }
#cd-mob-search { margin-bottom:12px; }

/* ── Flash messages ─────────────────────────── */
.cd-flash-wrap  { position:fixed; top:calc(var(--header-h)+8px); left:50%; transform:translateX(-50%); z-index:80; display:flex; flex-direction:column; gap:8px; width:min(500px,90vw); }
.cd-flash       { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 16px; border-radius:var(--radius-sm); font-weight:600; box-shadow:var(--shadow-lg); animation:cdSlideDown .25s ease; }
.cd-flash-success { background:var(--teal-light);   color:var(--teal-dark);  border-left:4px solid var(--teal); }
.cd-flash-error   { background:var(--danger-light);  color:var(--danger);    border-left:4px solid var(--danger); }
.cd-flash-info    { background:#EFF6FF; color:#1E40AF; border-left:4px solid #3B82F6; }
.cd-flash-close { background:none; border:none; cursor:pointer; color:inherit; opacity:.6; font-size:16px; padding:0; flex-shrink:0; }
@keyframes cdSlideDown { from { transform:translateY(-10px); opacity:0; } to { transform:none; opacity:1; } }

/* ── Toast ──────────────────────────────────── */
#cd-toasts { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.cd-toast  { background:var(--ink-2); color:#fff; padding:12px 18px; border-radius:var(--radius-sm); font-family:var(--font-heading); font-size:.875rem; font-weight:700; display:flex; align-items:center; gap:10px; box-shadow:var(--shadow-lg); pointer-events:all; max-width:340px; border-left:4px solid var(--amber); animation:cdToastIn .2s ease; }
.cd-toast.success { border-left-color:var(--teal); }
.cd-toast.error   { border-left-color:var(--danger); }
@keyframes cdToastIn { from { transform:translateX(20px); opacity:0; } to { transform:none; opacity:1; } }

/* ── Hero ───────────────────────────────────── */
.cd-hero { background:var(--ink); padding:88px 0 80px; overflow:hidden; position:relative; }
.cd-hero::before { content:''; position:absolute; top:0; right:0; bottom:0; left:50%; background:radial-gradient(ellipse 60% 70% at 80% 50%, rgba(217,119,6,.18) 0%,transparent 70%); pointer-events:none; }
.cd-hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; position:relative; }
.cd-hero-eyebrow { display:inline-flex; align-items:center; gap:7px; background:rgba(217,119,6,.15); color:var(--amber-mid); border:1px solid rgba(217,119,6,.3); font-family:var(--font-heading); font-size:.8125rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:6px 16px; border-radius:var(--radius-full); margin-bottom:20px; }
.cd-hero-title { color:#fff; font-size:clamp(2.2rem,5vw,3.5rem); font-weight:800; line-height:1.06; letter-spacing:-.03em; margin-bottom:16px; }
.cd-hero-sub   { color:rgba(255,255,255,.65); font-size:1.05rem; margin-bottom:30px; line-height:1.75; max-width:500px; }
.cd-hero-search-bar { display:flex; align-items:center; background:#fff; border-radius:var(--radius-lg); padding:5px; box-shadow:var(--shadow-lg); max-width:560px; margin-bottom:28px; border:2px solid var(--border); }
.cd-hero-search-bar select { border:none; outline:none; font-size:.875rem; padding:9px 12px; border-right:1.5px solid var(--border); font-family:var(--font-body); background:transparent; color:var(--muted); max-width:150px; cursor:pointer; }
.cd-hero-search-bar input  { flex:1; border:none; outline:none; font-size:.9375rem; padding:9px 12px; font-family:var(--font-body); background:transparent; color:var(--ink); min-width:0; }
.cd-hero-ctas  { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:40px; }
.cd-hero-stats { display:flex; gap:32px; }
.cd-hero-stat-n { font-family:var(--font-heading); font-size:1.75rem; font-weight:800; color:var(--amber); line-height:1; }
.cd-hero-stat-l { font-size:.8125rem; color:rgba(255,255,255,.45); margin-top:4px; }
.cd-hero-visual { position:relative; height:360px; }
.cd-float { position:absolute; background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:18px; border:1.5px solid rgba(0,0,0,.05); }
.cd-float-main  { top:10px; left:0; right:60px; animation:cdFloat 4s ease-in-out infinite; }
.cd-float-earn  { bottom:20px; right:0; width:175px; text-align:center; animation:cdFloat 4s ease-in-out infinite; animation-delay:-1.8s; }
.cd-float-sale  { top:47%; right:10px; width:148px; animation:cdFloat 3.8s ease-in-out infinite; animation-delay:-3.2s; }
@keyframes cdFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
.cd-float-doc-row { display:flex; gap:12px; align-items:center; margin-bottom:12px; }
.cd-float-icon  { width:44px; height:44px; background:var(--amber-light); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:22px; flex-shrink:0; }
.cd-float-title { font-family:var(--font-heading); font-weight:800; font-size:.9375rem; color:var(--ink); }
.cd-float-meta  { font-size:.75rem; color:var(--muted); margin-top:2px; }
.cd-float-doc-footer { display:flex; justify-content:space-between; align-items:center; padding-top:10px; border-top:2px solid var(--border); }
.cd-float-price { font-family:var(--font-heading); font-weight:800; font-size:1.1rem; }
.cd-float-stars { color:#F59E0B; letter-spacing:1px; }
.cd-float-big   { font-family:var(--font-heading); font-weight:800; font-size:1.5rem; color:var(--amber); line-height:1.1; }
.cd-float-label { font-size:.75rem; color:var(--muted); }
.cd-float-big.cd-teal { color:var(--teal); }

/* ── Subject strip ──────────────────────────── */
.cd-strip { background:#fff; border-bottom:1.5px solid var(--border); padding:12px 0; overflow-x:auto; scrollbar-width:none; }
.cd-strip::-webkit-scrollbar { display:none; }
.cd-strip-inner { display:flex; gap:8px; flex-wrap:nowrap; }
.cd-chip { display:flex; align-items:center; gap:6px; padding:7px 18px; border-radius:var(--radius-full); border:2px solid var(--border); font-family:var(--font-heading); font-size:.8125rem; font-weight:700; color:var(--muted); white-space:nowrap; flex-shrink:0; text-decoration:none; transition:all var(--t); cursor:pointer; }
.cd-chip:hover,.cd-chip.active { background:var(--amber); color:#fff; border-color:var(--amber); }

/* ── Section headings ───────────────────────── */
.cd-sec-head   { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:32px; gap:16px; flex-wrap:wrap; }
.cd-sec-center { text-align:center; margin-bottom:40px; }

/* ── Doc cards ──────────────────────────────── */
.cd-docs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:20px; }
.cd-doc-card  { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; transition:transform var(--t),box-shadow var(--t),border-color var(--t); display:flex; flex-direction:column; }
.cd-doc-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:#D1D5DB; }
.cd-doc-thumb { height:145px; overflow:hidden; position:relative; background:var(--surface-2); display:block; text-decoration:none; }
.cd-doc-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.cd-doc-card:hover .cd-doc-thumb img { transform:scale(1.06); }
.cd-doc-thumb-ph { height:100%; display:flex; align-items:center; justify-content:center; font-size:44px; }
.cd-doc-badge { position:absolute; top:10px; left:10px; }
.cd-doc-featured-badge { position:absolute; bottom:10px; left:10px; }
.cd-wish-btn { position:absolute; top:10px; right:10px; width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.9); border:none; font-size:14px; cursor:pointer; opacity:0; transition:opacity var(--t); }
.cd-doc-card:hover .cd-wish-btn { opacity:1; }
.cd-doc-body  { padding:14px; flex:1; display:flex; flex-direction:column; gap:5px; }
.cd-doc-title { font-family:var(--font-heading); font-size:.9375rem; font-weight:700; line-height:1.3; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.cd-doc-title a { color:var(--ink); }
.cd-doc-title a:hover { color:var(--amber-dark); }
.cd-doc-meta  { font-size:.8125rem; color:var(--muted); }
.cd-stars-fill { position:relative; color:#E5E7EB; }
.cd-stars-fill::after { content:'★★★★★'; position:absolute; left:0; top:0; color:#F59E0B; overflow:hidden; width:var(--pct,0%); white-space:nowrap; }
.cd-doc-rating { display:flex; align-items:center; gap:5px; font-size:.8125rem; color:var(--muted); }
.cd-doc-footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:12px; border-top:2px solid var(--border); }
.cd-doc-price  { font-family:var(--font-heading); font-size:1.15rem; font-weight:800; }
.cd-add-btn    { width:34px; height:34px; border-radius:var(--radius-sm); background:var(--amber); color:#fff; border:none; display:flex; align-items:center; justify-content:center; font-size:20px; font-weight:700; cursor:pointer; transition:all var(--t); text-decoration:none; flex-shrink:0; }
.cd-add-btn:hover    { background:var(--amber-dark); transform:scale(1.1); }
.cd-add-owned { background:var(--teal); font-size:14px; }
.cd-add-incart { background:var(--ink-2); font-size:14px; }

/* ── Steps ──────────────────────────────────── */
.cd-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.cd-step  { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:26px 20px; position:relative; transition:border-color var(--t),box-shadow var(--t); }
.cd-step:hover { border-color:var(--amber-mid); box-shadow:var(--shadow); }
.cd-step-num  { position:absolute; top:14px; right:16px; font-family:var(--font-mono); font-size:.8rem; font-weight:700; color:var(--amber-mid); }
.cd-step-icon { font-size:34px; margin-bottom:14px; }
.cd-step h3   { font-size:1rem; font-weight:700; margin-bottom:8px; }
.cd-step p    { font-size:.875rem; color:var(--muted); line-height:1.65; }

/* ── Sell banner ────────────────────────────── */
.cd-sell-banner { background:var(--ink-2); padding:72px 0; }
.cd-sell-inner  { display:flex; align-items:center; justify-content:space-between; gap:48px; flex-wrap:wrap; }
.cd-sell-copy h2 { color:#fff; font-size:clamp(1.6rem,3vw,2.2rem); margin-bottom:10px; }
.cd-sell-copy p  { color:rgba(255,255,255,.6); }
.cd-sell-perks   { display:flex; gap:40px; flex-wrap:wrap; }
.cd-sell-n { font-family:var(--font-heading); font-size:2.2rem; font-weight:800; color:var(--amber); line-height:1; }
.cd-sell-l { font-size:.8125rem; color:rgba(255,255,255,.45); margin-top:4px; }

/* ── Testimonials ───────────────────────────── */
.cd-testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.cd-testi { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:24px; }
.cd-testi-stars { color:#F59E0B; margin-bottom:10px; }
.cd-testi-q    { font-size:.9375rem; color:var(--muted); font-style:italic; line-height:1.75; margin-bottom:18px; }
.cd-testi-auth { display:flex; align-items:center; gap:10px; }
.cd-tav        { width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-size:.875rem; font-weight:800; flex-shrink:0; }
.cd-tauth-name { font-family:var(--font-heading); font-size:.875rem; font-weight:700; }
.cd-tauth-role { font-size:.75rem; color:var(--subtle); }

/* ── Stats section ──────────────────────────── */
.cd-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; text-align:center; }
.cd-stat-n { font-family:var(--font-heading); font-size:2.5rem; font-weight:800; color:var(--amber); line-height:1; margin-bottom:6px; }
.cd-stat-l { color:var(--muted); font-size:.875rem; }

/* ── Trust bar ──────────────────────────────── */
.cd-trust { background:#fff; border-top:1.5px solid var(--border); border-bottom:1.5px solid var(--border); padding:14px 0; }
.cd-trust-inner { display:flex; align-items:center; justify-content:space-around; flex-wrap:wrap; gap:14px; font-family:var(--font-heading); font-size:.875rem; font-weight:600; color:var(--muted); }

/* ── Marketplace layout ─────────────────────── */
.cd-page-banner { background:var(--surface); border-bottom:1.5px solid var(--border); padding:40px 0; }
.cd-page-banner h1 { margin-bottom:6px; }
.cd-page-banner p  { color:var(--muted); }
.cd-mkt-wrap   { padding:40px 0 80px; }
.cd-mkt-layout { display:grid; grid-template-columns:240px 1fr; gap:32px; align-items:start; }
.cd-filter-sidebar { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:20px; position:sticky; top:calc(var(--header-h)+16px); }
.cd-filter-header  { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.cd-filter-header h3 { font-size:1rem; font-weight:700; }
.cd-filter-group { margin-bottom:22px; }
.cd-filter-label { font-family:var(--font-heading); font-size:.75rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; display:block; }
.cd-filter-check { display:flex; align-items:center; gap:8px; padding:5px 0; cursor:pointer; font-size:.875rem; color:var(--muted); }
.cd-filter-check:hover { color:var(--ink); }
.cd-filter-check input { accent-color:var(--amber); width:16px; height:16px; cursor:pointer; }
.cd-price-range { display:flex; align-items:center; gap:8px; }
.cd-price-range span { color:var(--muted); flex-shrink:0; }
.cd-mkt-toolbar { display:flex; align-items:center; gap:12px; margin-bottom:16px; flex-wrap:wrap; }
.cd-mkt-search-form { flex:1; min-width:200px; }
.cd-search-wrap { position:relative; }
.cd-search-wrap svg { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--subtle); pointer-events:none; }
.cd-search-wrap input { width:100%; height:40px; padding:0 12px 0 38px; border:2px solid var(--border); border-radius:var(--radius-sm); font-size:.9rem; outline:none; transition:all var(--t); }
.cd-search-wrap input:focus { border-color:var(--amber); box-shadow:0 0 0 3px var(--amber-light); }
.cd-toolbar-right { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.cd-result-count { font-size:.875rem; color:var(--muted); white-space:nowrap; }
.cd-filter-toggle { display:none; padding:8px 14px; border:2px solid var(--border); border-radius:var(--radius-sm); background:#fff; font-family:var(--font-heading); font-size:.875rem; font-weight:700; cursor:pointer; }
.cd-active-filters { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; }
.cd-active-chip { background:var(--amber-light); color:var(--amber-dark); border:1.5px solid var(--amber-mid); border-radius:var(--radius-full); padding:4px 12px; font-size:.8125rem; font-weight:700; }
.cd-active-chip:hover { background:var(--amber-mid); }
.cd-empty-state { text-align:center; padding:72px 24px; }
.cd-empty-icon  { font-size:56px; margin-bottom:16px; }
.cd-empty-state h3 { font-size:1.4rem; margin-bottom:8px; }
.cd-empty-state p  { color:var(--muted); }
.cd-pagination { display:flex; gap:6px; justify-content:center; margin-top:48px; flex-wrap:wrap; }
.cd-page-btn   { display:flex; align-items:center; justify-content:center; min-width:38px; height:38px; padding:0 8px; border-radius:var(--radius-sm); border:2px solid var(--border); background:#fff; color:var(--muted); font-family:var(--font-heading); font-size:.875rem; font-weight:700; text-decoration:none; transition:all var(--t); }
.cd-page-btn:hover,.cd-page-btn.active { background:var(--amber); color:#fff; border-color:var(--amber); }

/* ── Document page ──────────────────────────── */
.cd-breadcrumb { padding:12px 0; font-size:.8125rem; color:var(--subtle); border-bottom:1.5px solid var(--border); }
.cd-breadcrumb .cd-container { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.cd-breadcrumb a { color:var(--muted); }
.cd-breadcrumb a:hover { color:var(--amber); }
.cd-breadcrumb span { color:var(--border); }
.cd-doc-page   { padding:40px 0 80px; }
.cd-doc-layout { display:grid; grid-template-columns:1fr 310px; gap:40px; align-items:start; }
.cd-doc-cover  { height:220px; border:2px solid var(--border); border-radius:var(--radius-lg); background:var(--surface-2); overflow:hidden; display:flex; align-items:center; justify-content:center; font-size:60px; margin-bottom:22px; }
.cd-doc-cover img { width:100%;height:100%;object-fit:cover; }
.cd-doc-cover-ph { font-size:60px; }
.cd-doc-tags   { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.cd-doc-meta-row { display:flex; flex-wrap:wrap; gap:14px; align-items:center; margin-bottom:20px; font-size:.875rem; color:var(--muted); }
.cd-seller-pill { display:flex; align-items:center; gap:8px; }
.cd-seller-av   { width:30px; height:30px; border-radius:50%; background:var(--amber-light); color:var(--amber-dark); display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-size:.75rem; font-weight:800; flex-shrink:0; }
.cd-seller-av-lg { width:48px; height:48px; font-size:1.1rem; }
.cd-meta-pill   { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--radius-full); padding:3px 10px; font-size:.8rem; }
.cd-rating-display { display:flex; align-items:center; gap:6px; }
.cd-doc-desc    { font-size:.9375rem; line-height:1.8; color:var(--muted); margin-bottom:24px; }
.cd-doc-includes { border:2px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; margin-bottom:24px; }
.cd-includes-title { padding:12px 18px; background:var(--surface); font-family:var(--font-heading); font-weight:700; font-size:.9375rem; border-bottom:1.5px solid var(--border); }
.cd-inc-row     { display:flex; align-items:center; gap:10px; padding:10px 18px; border-bottom:1px solid var(--border); font-size:.875rem; color:var(--muted); }
.cd-inc-row:last-child { border:none; }
.cd-inc-check   { color:var(--teal); font-weight:800; }
.cd-seller-card { display:flex; align-items:center; gap:14px; padding:18px; border:2px solid var(--border); border-radius:var(--radius-lg); margin-bottom:24px; }
.cd-seller-name  { font-family:var(--font-heading); font-weight:800; }
.cd-seller-college { font-size:.875rem; color:var(--muted); }
.cd-reviews-section { margin-bottom:24px; }
.cd-review      { padding:16px 0; border-bottom:1.5px solid var(--border); }
.cd-review:last-child { border:none; }
.cd-review-header { display:flex; align-items:center; gap:10px; margin-bottom:8px; font-size:.875rem; flex-wrap:wrap; }
.cd-review-date { color:var(--subtle); font-size:.8rem; }
.cd-review-text { color:var(--muted); font-size:.9rem; line-height:1.7; }
.cd-buy-card    { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:24px; position:sticky; top:calc(var(--header-h)+16px); }
.cd-buy-price   { font-family:var(--font-heading); font-size:2.4rem; font-weight:800; letter-spacing:-.02em; margin-bottom:4px; }
.cd-buy-sub     { font-size:.875rem; color:var(--muted); margin-bottom:20px; }
.cd-buy-divider { border:none; border-top:2px solid var(--border); margin:16px 0; }
.cd-buy-feature { display:flex; align-items:center; gap:8px; font-size:.875rem; color:var(--muted); padding:4px 0; }
.cd-check       { color:var(--teal); font-weight:800; }
.cd-secure-note { display:flex; align-items:center; justify-content:center; gap:6px; font-size:.8125rem; color:var(--subtle); margin-top:12px; }
.cd-rate-wrap   { padding:20px; border:2px solid var(--border); border-radius:var(--radius-lg); }
.cd-stars-input { display:flex; gap:4px; }
.cd-star        { font-size:28px; cursor:pointer; color:#E5E7EB; transition:color .1s; border:none; background:none; padding:2px; }
.cd-star.on,.cd-star:hover { color:#F59E0B; }
.cd-related-section { margin-top:56px; padding-top:40px; border-top:2px solid var(--border); }

/* ── Cart ───────────────────────────────────── */
.cd-cart-layout { display:grid; grid-template-columns:1fr 320px; gap:28px; align-items:start; }
.cd-cart-items  { display:flex; flex-direction:column; gap:12px; }
.cd-cart-row    { display:flex; gap:14px; align-items:flex-start; background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:16px; transition:border-color var(--t); }
.cd-cart-row:hover { border-color:#D1D5DB; }
.cd-cart-thumb  { width:56px; height:56px; border-radius:var(--radius-sm); background:var(--surface-2); display:flex; align-items:center; justify-content:center; font-size:26px; flex-shrink:0; overflow:hidden; }
.cd-cart-thumb img { width:100%;height:100%;object-fit:cover; }
.cd-cart-info   { flex:1; min-width:0; }
.cd-cart-title  { font-family:var(--font-heading); font-weight:700; font-size:.9375rem; color:var(--ink); display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cd-cart-meta   { font-size:.8125rem; color:var(--muted); margin-top:3px; }
.cd-cart-price  { font-family:var(--font-heading); font-weight:800; font-size:1rem; margin-top:6px; color:var(--amber-dark); }
.cd-cart-rm     { background:none; border:none; font-size:20px; color:var(--subtle); cursor:pointer; flex-shrink:0; padding:2px; transition:color var(--t); }
.cd-cart-rm:hover { color:var(--danger); }
.cd-summary-card  { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:22px; position:sticky; top:calc(var(--header-h)+16px); }
.cd-summary-title { font-family:var(--font-heading); font-size:1.1rem; font-weight:800; margin-bottom:16px; }
.cd-summary-row   { display:flex; justify-content:space-between; font-size:.9375rem; padding:9px 0; color:var(--muted); border-bottom:1.5px solid var(--border); }
.cd-summary-total { display:flex; justify-content:space-between; font-family:var(--font-heading); font-size:1.1rem; font-weight:800; padding:14px 0 0; }

/* ── Auth pages ─────────────────────────────── */
.cd-auth-wrap { min-height:calc(100vh - var(--header-h) - 80px); display:flex; align-items:center; justify-content:center; padding:40px 20px; background:var(--surface); }
.cd-auth-card { background:#fff; border:2px solid var(--border); border-radius:var(--radius-xl,24px); padding:40px; width:100%; max-width:440px; box-shadow:var(--shadow-lg); }
.cd-auth-logo a { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-heading); font-size:1.2rem; font-weight:800; color:var(--ink); text-decoration:none; margin-bottom:24px; }
.cd-auth-forgot { font-family:var(--font-body); font-size:.8rem; font-weight:400; color:var(--amber); letter-spacing:0; text-transform:none; }
.cd-auth-switch { text-align:center; font-size:.9rem; color:var(--muted); margin-top:20px; }

/* ── Dashboard ──────────────────────────────── */
.cd-dash-layout { display:grid; grid-template-columns:230px 1fr; gap:24px; align-items:start; padding:40px 0 80px; }
.cd-dash-sidebar { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; position:sticky; top:calc(var(--header-h)+16px); }
.cd-dash-profile { padding:20px; text-align:center; border-bottom:1.5px solid var(--border); background:var(--surface); }
.cd-dash-avatar  { width:60px; height:60px; border-radius:50%; margin:0 auto 10px; background:var(--amber-light); color:var(--amber-dark); display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-size:1.4rem; font-weight:800; overflow:hidden; }
.cd-dash-uname   { font-family:var(--font-heading); font-weight:800; }
.cd-dash-uemail  { font-size:.8rem; color:var(--subtle); }
.cd-dash-ucollege { font-size:.8rem; color:var(--muted); margin-top:3px; }
.cd-dash-nav     { padding:8px; }
.cd-dash-nav-link { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:var(--radius-sm); font-family:var(--font-heading); font-size:.875rem; font-weight:700; color:var(--muted); text-decoration:none; transition:all var(--t); }
.cd-dash-nav-link:hover,.cd-dash-nav-link.active { background:var(--amber-light); color:var(--amber-dark); }
.cd-dash-divider { border:none; border-top:1.5px solid var(--border); margin:6px 0; }
.cd-dash-section-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.cd-order-card   { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:18px; margin-bottom:12px; }
.cd-order-meta   { display:flex; align-items:center; gap:12px; margin-bottom:8px; flex-wrap:wrap; }
.cd-order-key    { font-family:var(--font-mono); font-size:.875rem; font-weight:700; color:var(--muted); }
.cd-order-date   { font-size:.875rem; color:var(--subtle); }
.cd-order-docs   { font-size:.9rem; color:var(--muted); margin-bottom:10px; }
.cd-order-footer { display:flex; align-items:center; justify-content:space-between; font-size:.875rem; color:var(--muted); }
.cd-order-total  { font-family:var(--font-heading); font-weight:800; color:var(--amber-dark); }
.cd-earnings-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.cd-earning-card { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:20px; text-align:center; }
.cd-earning-primary { border-color:var(--amber-mid); background:var(--amber-light); }
.cd-earning-n    { font-family:var(--font-heading); font-size:1.75rem; font-weight:800; color:var(--amber); }
.cd-earning-primary .cd-earning-n { font-size:2rem; }
.cd-earning-l    { font-size:.8125rem; color:var(--muted); margin-top:4px; }

/* ── Tables ─────────────────────────────────── */
.cd-table-wrap  { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; }
.cd-table-title { padding:14px 18px; font-family:var(--font-heading); font-weight:800; font-size:.9375rem; border-bottom:1.5px solid var(--border); }
.cd-table       { width:100%; border-collapse:collapse; font-size:.875rem; }
.cd-table th    { padding:11px 16px; background:var(--surface); font-family:var(--font-heading); font-size:.75rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); border-bottom:1.5px solid var(--border); text-align:left; }
.cd-table td    { padding:13px 16px; border-bottom:1.5px solid var(--border); vertical-align:middle; }
.cd-table tr:last-child td { border-bottom:none; }
.cd-table tr:hover td { background:var(--surface); }
.cd-table-link  { color:var(--ink); font-weight:600; }
.cd-table-link:hover { color:var(--amber); }
.cd-action-btns { display:flex; gap:6px; flex-wrap:wrap; }

/* ── Admin ──────────────────────────────────── */
.cd-admin-wrap  { padding:28px 0 80px; }
.cd-admin-nav   { display:flex; align-items:center; gap:4px; margin-bottom:28px; background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:8px; flex-wrap:wrap; }
.cd-admin-brand { font-family:var(--font-heading); font-weight:800; font-size:.9rem; color:var(--ink); padding:6px 12px; margin-right:8px; }
.cd-admin-nav-link { padding:8px 14px; border-radius:var(--radius-sm); font-family:var(--font-heading); font-size:.875rem; font-weight:700; color:var(--muted); transition:all var(--t); }
.cd-admin-nav-link:hover,.cd-admin-nav-link.active { background:var(--amber-light); color:var(--amber-dark); }
.cd-admin-stats { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-bottom:28px; }
.cd-admin-stat  { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:18px; text-align:center; }
.cd-admin-stat-warn .cd-admin-stat-n { color:var(--danger); }
.cd-admin-stat-icon { font-size:22px; margin-bottom:6px; }
.cd-admin-stat-n { font-family:var(--font-heading); font-size:1.75rem; font-weight:800; color:var(--amber); }
.cd-admin-stat-l { font-size:.8rem; color:var(--muted); }
.cd-admin-tabs  { display:flex; gap:4px; margin-bottom:0; background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg) var(--radius-lg) 0 0; padding:8px 8px 0; border-bottom:none; }
.cd-admin-tab   { padding:8px 16px; font-family:var(--font-heading); font-size:.875rem; font-weight:700; color:var(--muted); text-decoration:none; border-bottom:3px solid transparent; margin-bottom:-2px; transition:all var(--t); }
.cd-admin-tab:hover,.cd-admin-tab.active { color:var(--amber); border-bottom-color:var(--amber); }
.cd-admin-tabs + .cd-table-wrap { border-radius:0 0 var(--radius-lg) var(--radius-lg); }
.cd-settings-form .cd-settings-section { background:#fff; border:2px solid var(--border); border-radius:var(--radius-lg); padding:22px 24px; margin-bottom:20px; }
.cd-settings-form .cd-settings-section h3 { font-size:1rem; font-weight:800; margin-bottom:16px; }
.cd-sell-terms  { font-size:.9rem; color:var(--muted); }

/* ── Footer ─────────────────────────────────── */
#cd-footer { background:var(--ink); color:rgba(255,255,255,.55); padding:72px 0 32px; }
.cd-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.cd-footer-brand p { font-size:.875rem; line-height:1.75; max-width:280px; margin:12px 0 18px; }
.cd-footer-logo { display:flex; align-items:center; gap:8px; font-family:var(--font-heading); font-size:1.4rem; font-weight:800; color:#fff; letter-spacing:-.02em; }
.cd-footer-logo span { font-size:18px; }
.cd-footer-logo em { font-style:normal; color:var(--amber-mid); }
.cd-socials { display:flex; gap:8px; }
.cd-social  { width:34px; height:34px; border-radius:var(--radius-sm); background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; font-size:14px; color:rgba(255,255,255,.5); transition:all var(--t); }
.cd-social:hover { background:var(--amber); color:#fff; }
.cd-footer-col h4 { color:#fff; font-size:.875rem; font-weight:800; margin-bottom:14px; }
.cd-footer-col a  { display:block; font-size:.875rem; color:rgba(255,255,255,.45); margin-bottom:9px; transition:color var(--t); }
.cd-footer-col a:hover { color:#fff; }
.cd-footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:24px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.8125rem; }

/* ── Subject page ───────────────────────────── */
.cd-subject-hero { background:var(--surface); border-bottom:1.5px solid var(--border); padding:40px 0; }
.cd-subject-hero h1 { margin-bottom:6px; }

/* ── Scroll reveal ──────────────────────────── */
[data-reveal] > * { opacity:0; transform:translateY(20px); transition:opacity .5s ease, transform .5s ease; }
[data-reveal] > *.visible { opacity:1; transform:none; }

/* ── Back to top ────────────────────────────── */
#cd-btt { position:fixed; bottom:24px; right:24px; width:42px; height:42px; border-radius:50%; background:var(--amber); color:#fff; border:none; font-size:18px; cursor:pointer; opacity:0; transition:opacity .3s; z-index:50; box-shadow:0 4px 14px rgba(217,119,6,.4); }
#cd-btt.show { opacity:1; }

/* ── Responsive ─────────────────────────────── */
@media(max-width:1024px) {
  .cd-mkt-layout { grid-template-columns:1fr; }
  .cd-filter-sidebar { display:none; position:fixed; top:0; left:0; bottom:0; width:280px; border-radius:0; z-index:200; overflow-y:auto; }
  .cd-filter-sidebar.open { display:block; }
  .cd-filter-toggle { display:flex; align-items:center; gap:6px; }
  .cd-admin-stats { grid-template-columns:repeat(3,1fr); }
  .cd-footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .cd-dash-layout { grid-template-columns:1fr; }
  .cd-dash-sidebar { position:static; }
  .cd-steps { grid-template-columns:1fr 1fr; }
  .cd-stats-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .cd-hero-inner { grid-template-columns:1fr; }
  .cd-hero-visual { display:none; }
  .cd-nav-links,.cd-nav-search { display:none; }
  .cd-burger { display:flex; }
  .cd-doc-layout { grid-template-columns:1fr; }
  .cd-cart-layout { grid-template-columns:1fr; }
  .cd-testi-grid { grid-template-columns:1fr; }
  .cd-sell-inner { flex-direction:column; }
  .cd-footer-grid { grid-template-columns:1fr; gap:24px; }
  .cd-steps { grid-template-columns:1fr; }
  .cd-admin-stats { grid-template-columns:1fr 1fr; }
  .cd-earnings-grid { grid-template-columns:1fr 1fr; }
  .cd-section { padding:48px 0; }
  .cd-field-row,.cd-field-row-3 { grid-template-columns:1fr; }
}
@media(max-width:480px) {
  .cd-container { padding:0 16px; }
  .cd-docs-grid { grid-template-columns:1fr 1fr; gap:12px; }
}
@media(prefers-reduced-motion:reduce) { *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; } }
