/* ============================================================
   MANGAL MALL – Digital Invitation Module
   Shared design system  (matches live mangalmall.com look)
   ============================================================ */
:root{
  --maroon:#7a1228;
  --maroon-dark:#5c0f20;
  --maroon-soft:#9a2a40;
  --gold:#d9a441;
  --gold-soft:#f0d9a8;
  --saffron:#f4a93c;
  --crimson:#c0204c;
  --crimson-dark:#a51840;
  --bg:#f6f2ef;
  --bg-alt:#efe9e4;
  --card:#ffffff;
  --ink:#262229;
  --muted:#7c7682;
  --line:#e9e2dc;
  --green:#2e9e6b;
  --blue:#2f6fed;
  --radius:14px;
  --shadow:0 10px 30px rgba(60,20,30,.08);
  --shadow-sm:0 4px 14px rgba(60,20,30,.07);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{margin:0 0 .4em;font-weight:600;line-height:1.2}
.serif{font-family:'Poppins','Inter',system-ui,-apple-system,sans-serif;font-weight:700}
.di-wrap{max-width:1200px;margin:0 auto;padding:0 22px}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---------- Section heading w/ ornament ---------- */
.sec{padding:46px 0}
.sec.alt{background:var(--bg-alt)}
.sec-head{text-align:center;margin-bottom:30px}
.ornament{color:var(--gold);font-size:13px;letter-spacing:6px;display:block;margin-bottom:6px}
.ornament:before{content:"✦ ———————";opacity:.6}
.ornament:after{content:"——————— ✦"}
.sec-head h2{font-size:27px;color:#2b2127}
.sec-head p{color:var(--muted);max-width:680px;margin:6px auto 0}

/* ---------- Breadcrumb ---------- */
.crumb{font-size:12.5px;color:var(--muted);padding:14px 0}
.crumb a:hover{color:var(--crimson)}
.crumb span{color:var(--maroon)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;
  font-family:inherit;font-weight:600;font-size:14px;border-radius:10px;padding:11px 20px;transition:.15s}
.btn-primary{background:linear-gradient(135deg,var(--crimson),var(--crimson-dark));color:#fff}
.btn-primary:hover{filter:brightness(1.07);color:#fff;text-decoration:none}
.btn-gold{background:linear-gradient(135deg,var(--saffron),var(--gold));color:#5c3a06}
.btn-gold:hover{filter:brightness(1.05);color:#5c3a06;text-decoration:none}
.btn-outline{background:#fff;border:1.5px solid var(--crimson);color:var(--crimson)}
.btn-outline:hover{background:#fff0f3;color:var(--crimson);text-decoration:none}
.btn-ghost{background:#f3ece7;color:#5a5159}
.btn-dark{background:var(--maroon);color:#fff}
.btn-lg{padding:14px 28px;font-size:15px}
.btn-block{width:100%;justify-content:center}
.btn-sm{padding:7px 13px;font-size:12.5px;border-radius:8px}

/* ---------- Pills / tags ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);
  border-radius:30px;padding:7px 15px;font-size:13px;color:#5a5159;cursor:pointer;transition:.15s}
.pill:hover{border-color:var(--crimson);color:var(--crimson)}
.pill.active{background:var(--crimson);color:#fff;border-color:var(--crimson)}
.tag{display:inline-block;background:var(--gold-soft);color:#7a5a16;font-size:11px;font-weight:600;
  padding:3px 9px;border-radius:6px;letter-spacing:.3px}
.tag.new{background:#e7f7ee;color:var(--green)}
.tag.lang{background:#eef2ff;color:#3a52b4}

/* ---------- Cards / grids ---------- */
.di-grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g5{grid-template-columns:repeat(5,1fr)}
@media(max-width:980px){.g4,.g5{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.g2,.g3,.g4,.g5{grid-template-columns:1fr}}

/* invitation card */
.inv-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:.18s;cursor:pointer;display:flex;flex-direction:column;text-decoration:none}
.inv-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);text-decoration:none}
.inv-thumb{position:relative;aspect-ratio:3/4.2;background:var(--bg-alt);overflow:hidden}
.inv-thumb img{width:100%;height:100%;object-fit:cover}
.inv-thumb .heart{position:absolute;top:10px;right:10px;background:#fff;border-radius:50%;width:30px;height:30px;
  display:grid;place-items:center;box-shadow:var(--shadow-sm);font-size:14px;color:var(--crimson);cursor:pointer;transition:.15s}
.inv-thumb .heart.wishlisted{background:var(--crimson);color:#fff}
.btn.wishlisted{background:var(--crimson);color:#fff;border-color:var(--crimson)}
.inv-thumb .ribbon{position:absolute;top:10px;left:0;background:var(--crimson);color:#fff;font-size:11px;
  font-weight:600;padding:3px 11px;border-radius:0 6px 6px 0}
.inv-body{padding:12px 14px;text-align:center}
.inv-body .t{font-weight:600;font-size:14.5px;color:#2b2127}
.inv-body .s{font-size:12px;color:var(--muted);margin-top:2px}
.inv-body .price{margin-top:7px;font-weight:700;color:var(--crimson)}
.inv-body .price del{color:var(--muted);font-weight:400;font-size:12px;margin-left:5px}

/* category card */
.cat-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:.18s;display:block;text-decoration:none}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);text-decoration:none}
.cat-card img{width:100%;height:100%;object-fit:cover}
.cat-card .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(45,10,20,.82),rgba(45,10,20,.05) 60%)}
.cat-card .lbl{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff}
.cat-card .lbl b{font-size:17px;display:block}
.cat-card .lbl span{font-size:12px;opacity:.85}

/* ---------- Steps strip ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:760px){.steps{grid-template-columns:repeat(2,1fr)}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.step:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:rgba(154,33,67,.18)}
.step .ico{width:54px;height:54px;border-radius:14px;margin:0 auto 12px;display:grid;place-items:center;
  font-size:24px;background:var(--gold-soft);color:#9a6b12}
.step b{font-size:14px;letter-spacing:.5px}
.step p{font-size:12.5px;color:var(--muted);margin:6px 0 0}

/* ---------- Hero ---------- */
.di-hero{background:linear-gradient(120deg,#fbf3ea,#f7e7df);position:relative;overflow:hidden;
  border-radius:18px;padding:48px 32px;margin-bottom:8px}
.di-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
@media(max-width:900px){.di-hero-grid{grid-template-columns:1fr}}
.di-tag{display:inline-block;background:#fff;color:var(--crimson);border:1px solid var(--gold-soft);
  border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.7px;padding:5px 14px;margin-bottom:14px}
.di-hero h1{font-family:'Poppins','Inter',system-ui,-apple-system,sans-serif;font-size:40px;font-weight:700;color:#3a1320;
  line-height:1.12;margin:0 0 14px}
@media(max-width:600px){.di-hero h1{font-size:26px}}
.di-hero-desc{font-size:15px;color:#5a4a50;max-width:520px;margin-bottom:22px;line-height:1.6}
.di-stats{display:flex;gap:28px;margin-top:24px;flex-wrap:wrap}
.di-stat-val{font-size:22px;font-weight:700;color:var(--crimson)}
.di-stat-lbl{font-size:11px;color:#888;margin-top:2px}
.di-hero-imgs{display:flex;gap:14px;justify-content:center}
.di-hero-img{width:46%;border-radius:14px;box-shadow:var(--shadow);object-fit:cover;max-height:300px}

/* ---------- Promise band ---------- */
.promise-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow-sm)}
.promise-card .pico{font-size:28px;margin-bottom:10px}
.promise-card h3{font-size:15px;font-weight:700;margin:0 0 6px;color:#3a1320}
.promise-card p{font-size:12px;color:#888;margin:0}

/* ---------- Note ---------- */
.note{background:#fff8ec;border:1px solid var(--gold-soft);border-radius:10px;padding:13px 15px;font-size:13px;color:#7a5a16}
.note.green{background:#f0fbf5;border-color:#bfe7d2;color:#1d7a4f}
.note.blue{background:#f1f5ff;border-color:#cdd9fb;color:#2f4aa0}

/* ============================================================
   EXTENDED COMPONENTS  (categories · form · dashboard · etc.)
   ============================================================ */

/* ---------- Panel ---------- */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;border-bottom:1px solid var(--line);background:#faf7f5;gap:10px}
.panel-head h3{margin:0;font-size:15px;font-weight:600;color:#2b2127}
.panel-body{padding:16px 18px}

/* ---------- Status badges ---------- */
.status{display:inline-flex;align-items:center;padding:4px 11px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}
.st-approved{background:#e7f7ee;color:#1d7a4f}
.st-review{background:#fff0f3;color:var(--crimson)}
.st-pending{background:#fff8ec;color:#b07d20}

/* ---------- KV rows ---------- */
.kv{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--line);font-size:13.5px;gap:12px;flex-wrap:wrap}
.kv:last-child{border-bottom:none}
.kv>span:first-child{color:var(--muted);flex-shrink:0}

/* ---------- Checkout stepper ---------- */
.flow{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:18px 0 26px}
.node{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--muted)}
.node.active{color:var(--crimson);font-weight:600}
.node.done{color:var(--green)}
.dot{width:26px;height:26px;border-radius:50%;border:2px solid currentColor;display:grid;place-items:center;font-size:11px;font-weight:700;flex-shrink:0}
.node.done .dot{background:var(--green);border-color:var(--green);color:#fff}
.node.active .dot{background:var(--crimson);border-color:var(--crimson);color:#fff}
.bar{flex:1;height:2px;background:var(--line);border-radius:2px;min-width:20px;max-width:60px}

/* ---------- Form components ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:600;color:#5a4a50;margin-bottom:6px}
.input{width:100%;border:1.5px solid var(--line);border-radius:9px;padding:10px 14px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff;transition:.15s;outline:none;box-sizing:border-box}
.input:focus{border-color:var(--crimson);box-shadow:0 0 0 3px rgba(192,32,76,.08)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.row2{grid-template-columns:1fr}}
.divider{height:1px;background:var(--line);margin:18px 0}
.req{color:var(--crimson)}
.hint{font-size:11.5px;color:var(--muted);margin-top:4px;display:block}

/* ---------- Upload dropzone ---------- */
.upload{border:1.5px dashed var(--gold);border-radius:10px;padding:22px;text-align:center;background:var(--gold-soft);cursor:pointer;font-size:13px;color:#7a5a16;transition:.15s}
.upload:hover{background:#ead8a0}

/* ---------- Chip (small info pill) ---------- */
.chip{display:inline-flex;align-items:center;background:#f3ece7;border-radius:8px;padding:5px 12px;font-size:12px;color:#5a4a50;font-weight:500;gap:4px}

/* ---------- Notification rows ---------- */
.notif{display:flex;align-items:flex-start;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.notif:last-child{border-bottom:none}
.ni{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:18px;flex-shrink:0}
.ni.wa{background:#e7f8ef}
.ni.em{background:#eef2ff}
.ni.be{background:#fff0f3}
.nt{font-size:13px;color:var(--ink);line-height:1.4}
.nm{font-size:11.5px;color:var(--muted);margin-top:2px}
.notif time{font-size:11px;color:var(--muted);flex-shrink:0;padding-top:2px;margin-left:auto}

/* ---------- Order timeline ---------- */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:'';position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-item{position:relative;margin-bottom:18px}
.tl-item:last-child{margin-bottom:0}
.tl-dot{position:absolute;left:-28px;top:0;width:20px;height:20px;border-radius:50%;background:#d8cec6;color:#fff;display:grid;place-items:center;font-size:11px;font-weight:600}
.tl-dot.done{background:var(--green)}
.tl-dot.active{background:var(--crimson)}
.tl-item b{font-size:13.5px;display:block}
.tl-time{font-size:11.5px;color:var(--muted);margin-top:2px}

/* ---------- Number badge ---------- */
.nbadge{display:inline-flex;align-items:center;justify-content:center;background:var(--crimson);color:#fff;border-radius:50%;width:20px;height:20px;font-size:10px;font-weight:700}

/* ---------- WYSIWYG form overlay ---------- */
.ustage{position:relative;display:block;border-radius:10px;overflow:hidden}
.ustage img{display:block;width:100%;transition:opacity .25s}
.ustage.focus img{opacity:.55}
.ubox{position:absolute;border:1.5px solid transparent;border-radius:3px;transition:border .15s,box-shadow .15s,background .15s,opacity .15s;box-sizing:border-box;display:flex;overflow:hidden}
.ubox .utext{flex:1;display:flex;align-items:center;line-height:1.12;padding:0 2px;overflow:hidden;opacity:0;transition:opacity .15s}
.ubox .ulab{position:absolute;top:-9px;left:-2px;transform:translateY(-100%);background:var(--crimson);color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:5px;white-space:nowrap;opacity:0;transition:.15s;z-index:2}
.ubox.on{border-color:var(--crimson);background:rgba(255,255,255,.45);box-shadow:0 0 0 2px rgba(192,32,76,.18)}
.ubox.on .utext{opacity:1;text-shadow:0 1px 0 #fff}
.ubox.on .ulab{opacity:1}

/* ---------- WYSIWYG preview overlay ---------- */
.pstage{position:relative;border-radius:10px;overflow:hidden;cursor:pointer}
.pstage img{display:block;width:100%;transition:opacity .25s,filter .25s}
.pwm{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;transition:opacity .25s}
.pbox{position:absolute;display:flex;align-items:center;overflow:hidden;line-height:1.12;opacity:0;transition:opacity .2s;pointer-events:none}
.pstage:hover img,.pstage.pin img{opacity:.5;filter:saturate(.9)}
.pstage:hover .pwm,.pstage.pin .pwm{opacity:0}
.pstage:hover .pbox,.pstage.pin .pbox{opacity:1}

/* ---------- Progress bar ---------- */
.prog-bar{height:8px;background:#eee5de;border-radius:6px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--saffron),var(--gold));border-radius:6px;transition:width .4s}

/* ---------- Chat bubble ---------- */
.bubble-in{background:#f3ece7;border-radius:10px 10px 10px 2px;padding:9px 12px;font-size:13px;max-width:85%;margin-bottom:10px}
.bubble-out{background:#fdeef2;border-radius:10px 10px 2px 10px;padding:9px 12px;font-size:13px;max-width:85%;margin-left:auto;margin-bottom:10px}
.bubble-time{font-size:11px;color:var(--muted);margin-top:4px}

/* ================================================================
   SPECIFICITY OVERRIDES — .di-wrap scope beats profile-layout CSS
   ================================================================ */

/* Panel card */
.di-wrap .panel{background:#fff!important;border:1px solid #e9e2dc!important;border-radius:14px!important;box-shadow:0 4px 14px rgba(60,20,30,.07)!important;overflow:hidden}
.di-wrap .panel-head{display:flex!important;align-items:center!important;justify-content:space-between!important;padding:13px 18px!important;border-bottom:1px solid #e9e2dc!important;background:#faf7f5!important;gap:10px!important}
.di-wrap .panel-head h3{margin:0!important;font-size:15px!important;font-weight:600!important;color:#2b2127!important}
.di-wrap .panel-body{padding:16px 18px!important}

/* Inputs / selects / textareas */
.di-wrap .input,
.di-wrap input.input,
.di-wrap select.input,
.di-wrap textarea.input{width:100%!important;border:1.5px solid #e9e2dc!important;border-radius:9px!important;padding:10px 14px!important;font-size:14px!important;font-family:'Poppins',sans-serif!important;color:#262229!important;background:#fff!important;box-shadow:none!important;outline:none!important;height:auto!important;line-height:1.5!important;display:block!important;transition:border-color .15s,box-shadow .15s;-webkit-appearance:auto;appearance:auto}
.di-wrap .input:focus,.di-wrap input.input:focus,.di-wrap select.input:focus,.di-wrap textarea.input:focus{border-color:#c0204c!important;box-shadow:0 0 0 3px rgba(192,32,76,.08)!important}
.di-wrap textarea.input{resize:vertical!important}

/* Field group */
.di-wrap .field{margin-bottom:16px!important}
.di-wrap .field>label,.di-wrap .field label{display:block!important;font-size:12.5px!important;font-weight:600!important;color:#5a4a50!important;margin-bottom:6px!important;font-family:'Poppins',sans-serif!important}
.di-wrap .row2{display:grid!important;grid-template-columns:1fr 1fr!important;gap:14px!important}
@media(max-width:600px){.di-wrap .row2{grid-template-columns:1fr!important}}
.di-wrap .divider{height:1px!important;background:#e9e2dc!important;margin:18px 0!important;border:none!important}
.di-wrap .req{color:#c0204c!important}

/* Hint text — must show as block */
.di-wrap .hint,.di-wrap span.hint,.di-wrap div.hint{font-size:11.5px!important;color:#7c7682!important;margin-top:5px!important;display:block!important;line-height:1.4!important}

/* Pills */
.di-wrap .pill{display:inline-flex!important;align-items:center!important;gap:6px!important;background:#fff!important;border:1px solid #e9e2dc!important;border-radius:30px!important;padding:7px 15px!important;font-size:13px!important;color:#5a5159!important;cursor:pointer!important;transition:.15s!important;text-decoration:none!important}
.di-wrap .pill:hover{border-color:#c0204c!important;color:#c0204c!important}
.di-wrap .pill.active{background:#c0204c!important;color:#fff!important;border-color:#c0204c!important}

/* Status badges */
.di-wrap .status{display:inline-flex!important;align-items:center!important;padding:4px 11px!important;border-radius:20px!important;font-size:11.5px!important;font-weight:600!important;white-space:nowrap!important}
.di-wrap .st-approved{background:#e7f7ee!important;color:#1d7a4f!important}
.di-wrap .st-review{background:#fff0f3!important;color:#c0204c!important}
.di-wrap .st-pending{background:#fff8ec!important;color:#b07d20!important}

/* KV rows */
.di-wrap .kv{display:flex!important;justify-content:space-between!important;align-items:baseline!important;padding:7px 0!important;border-bottom:1px solid #e9e2dc!important;font-size:13.5px!important;gap:12px!important;flex-wrap:wrap!important}
.di-wrap .kv:last-child{border-bottom:none!important}
.di-wrap .kv>span:first-child{color:#7c7682!important;flex-shrink:0!important}

/* Checkout stepper */
.di-wrap .flow{display:flex!important;align-items:center!important;gap:6px!important;flex-wrap:wrap!important;margin:18px 0 26px!important}
.di-wrap .node{display:flex!important;align-items:center!important;gap:7px!important;font-size:13px!important;font-weight:500!important;color:#7c7682!important}
.di-wrap .node.active{color:#c0204c!important;font-weight:600!important}
.di-wrap .node.done{color:#2e9e6b!important}
.di-wrap .dot{width:26px!important;height:26px!important;border-radius:50%!important;border:2px solid currentColor!important;display:grid!important;place-items:center!important;font-size:11px!important;font-weight:700!important;flex-shrink:0!important}
.di-wrap .node.done .dot{background:#2e9e6b!important;border-color:#2e9e6b!important;color:#fff!important}
.di-wrap .node.active .dot{background:#c0204c!important;border-color:#c0204c!important;color:#fff!important}
.di-wrap .bar{flex:1!important;height:2px!important;background:#e9e2dc!important;border-radius:2px!important;min-width:20px!important;max-width:60px!important}

/* Note boxes */
.di-wrap .note{background:#fff8ec!important;border:1px solid #f0d9a8!important;border-radius:10px!important;padding:13px 15px!important;font-size:13px!important;color:#7a5a16!important}
.di-wrap .note.green{background:#f0fbf5!important;border-color:#bfe7d2!important;color:#1d7a4f!important}
.di-wrap .note.blue{background:#f1f5ff!important;border-color:#cdd9fb!important;color:#2f4aa0!important}

/* Buttons */
.di-wrap .btn{display:inline-flex!important;align-items:center!important;gap:8px!important;border:none!important;cursor:pointer!important;font-family:'Poppins',sans-serif!important;font-weight:600!important;font-size:14px!important;border-radius:10px!important;padding:11px 20px!important;transition:.15s!important;text-decoration:none!important;line-height:1.2!important}
.di-wrap .btn-primary{background:linear-gradient(135deg,#c0204c,#a51840)!important;color:#fff!important}
.di-wrap .btn-primary:hover,.di-wrap .btn-primary:focus{filter:brightness(1.07)!important;color:#fff!important}
.di-wrap .btn-gold{background:linear-gradient(135deg,#f4a93c,#d9a441)!important;color:#5c3a06!important}
.di-wrap .btn-outline{background:#fff!important;border:1.5px solid #c0204c!important;color:#c0204c!important}
.di-wrap .btn-ghost{background:#f3ece7!important;color:#5a5159!important}
.di-wrap .btn-lg{padding:14px 28px!important;font-size:15px!important}
.di-wrap .btn-sm{padding:7px 13px!important;font-size:12.5px!important;border-radius:8px!important}
.di-wrap .btn-block{width:100%!important;justify-content:center!important}

/* Chip */
.di-wrap .chip{display:inline-flex!important;align-items:center!important;background:#f3ece7!important;border-radius:8px!important;padding:5px 12px!important;font-size:12px!important;color:#5a4a50!important;font-weight:500!important;gap:4px!important}

/* Muted */
.di-wrap .muted{color:#7c7682!important}

/* Upload zone */
.di-wrap .upload{border:1.5px dashed #d9a441!important;border-radius:10px!important;padding:22px!important;text-align:center!important;background:#fdf4e3!important;cursor:pointer!important;font-size:13px!important;color:#7a5a16!important;transition:.15s!important;display:block!important}

/* Notification rows */
.di-wrap .notif{display:flex!important;align-items:flex-start!important;gap:12px!important;padding:13px 0!important;border-bottom:1px solid #e9e2dc!important}
.di-wrap .notif:last-child{border-bottom:none!important}
.di-wrap .ni{width:36px!important;height:36px!important;border-radius:10px!important;display:grid!important;place-items:center!important;font-size:18px!important;flex-shrink:0!important}
.di-wrap .ni.wa{background:#e7f8ef!important}
.di-wrap .ni.em{background:#eef2ff!important}
.di-wrap .ni.be{background:#fff0f3!important}
.di-wrap .nt{font-size:13px!important;color:#262229!important;line-height:1.4!important}
.di-wrap .nm{font-size:11.5px!important;color:#7c7682!important;margin-top:2px!important}

/* Progress bar */
.di-wrap .prog-bar{height:8px!important;background:#eee5de!important;border-radius:6px!important;overflow:hidden!important}
.di-wrap .prog-fill{height:100%!important;background:linear-gradient(90deg,#f3ae30,#d9a441)!important;border-radius:6px!important}

/* Section heading */
.di-wrap .sec-head{text-align:center!important;margin-bottom:30px!important}
.di-wrap .ornament{color:#d9a441!important;font-size:13px!important;letter-spacing:6px!important;display:block!important;margin-bottom:6px!important}
.di-wrap .sec-head h2{font-size:27px!important;color:#2b2127!important}
.di-wrap .sec-head p{color:#7c7682!important;max-width:680px!important;margin:6px auto 0!important}

/* ================================================================
   RESPONSIVE LAYOUT UTILITIES + MEDIA QUERIES
   ================================================================ */

/* ── Two-column grid utilities (replace inline styles in blades) ─ */
.di-2col-lheavy  {display:grid;grid-template-columns:.95fr 1.05fr;gap:40px;align-items:start}
.di-2col-rheavy  {display:grid;grid-template-columns:.85fr 1.15fr;gap:30px;align-items:start}
.di-2col-preview {display:grid;grid-template-columns:.9fr 1.1fr;gap:30px;align-items:start}
.di-payment-grid {display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:start}
.di-detail-grid  {display:grid;grid-template-columns:1.4fr .9fr;gap:24px;align-items:start}
.di-dashboard-grid{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}
.di-sidebar-left {display:grid;grid-template-columns:220px 1fr;gap:26px;align-items:start}
.di-order-inner-sm{display:grid;grid-template-columns:120px 1fr;gap:18px}
.di-order-inner-md{display:grid;grid-template-columns:130px 1fr;gap:18px}
.di-sticky{position:sticky;top:90px}

/* Filter toggle button — visible only on mobile */
.di-filter-toggle{display:none}

/* ── Tablet / Small Screens: ≤ 768px ────────────────────────── */
@media(max-width:768px){

  .di-wrap{padding:0 14px}
  .sec{padding:24px 0}

  /* All two-column layouts → single column */
  .di-2col-lheavy,
  .di-2col-rheavy,
  .di-2col-preview,
  .di-payment-grid,
  .di-detail-grid,
  .di-dashboard-grid,
  .di-sidebar-left{grid-template-columns:1fr}

  /* Sticky panels → normal flow */
  .di-sticky{position:static;top:auto}

  /* Form page: show form fields FIRST, preview card below */
  .di-form-preview{order:2}
  .di-form-fields{order:1}

  /* Payment page: order summary ABOVE payment form */
  .di-payment-grid>form{order:2}
  .di-payment-grid>div{order:1}

  /* Dashboard: notifications sidebar BELOW orders */
  .di-dashboard-grid>aside{order:2}
  .di-dashboard-grid>div:first-child{order:1}

  /* Order detail: right panel (chat/revision) below timeline */
  .di-detail-grid>div:last-child{order:2}

  /* Inner order image+details card → single column */
  .di-order-inner-sm,
  .di-order-inner-md{grid-template-columns:1fr}

  /* Stepper: hide text labels, keep dots */
  .di-wrap .node>span:not(.dot){display:none}
  .di-wrap .bar{min-width:8px;max-width:18px}
  .di-wrap .flow{margin:12px 0 18px;justify-content:center}

  /* Section heading */
  .di-wrap .sec-head h2{font-size:22px!important}

  /* Subcategory: filter sidebar collapses; toggle button shows */
  .di-filter-sidebar{display:none}
  .di-filter-sidebar.open{display:block}
  .di-filter-toggle{display:flex;width:100%;margin-bottom:16px;justify-content:space-between;align-items:center}

  /* Categories: search bar stacks vertically */
  .di-wrap .di-search-bar{flex-direction:column}
  .di-wrap .di-search-bar select.input,
  .di-wrap .di-search-bar input.input{max-width:100%!important;min-width:0!important;width:100%!important}
  .di-wrap .di-search-bar .btn{width:100%;justify-content:center}

  /* Download buttons in dashboard wrap nicely */
  .di-wrap .di-dl-row{flex-direction:column}
  .di-wrap .di-dl-row .btn{width:100%;justify-content:center}

  /* Hero section */
  .di-hero{padding:28px 18px}
}

/* ── Phone: ≤ 480px ─────────────────────────────────────────── */
@media(max-width:480px){
  .di-wrap{padding:0 10px}
  .di-wrap .btn-lg{padding:12px 16px!important;font-size:14px!important}
  .di-wrap .btn-block{font-size:14px!important}
  .di-wrap .panel-body{padding:12px 14px!important}
  .di-wrap .panel-head{padding:10px 14px!important}
  .crumb{font-size:11px;padding:10px 0}
  .di-wrap .sec-head h2{font-size:19px!important}
  .di-wrap h1.serif{font-size:22px!important}
  .di-wrap .notif time{display:none}
  .di-stats{gap:16px}
}
