/* ================================================
       DESIGN SYSTEM - KERALA LITERARY MAGAZINE
    ================================================ */
    /* KENZ Malayalam Font Family - Body (text) */
    @font-face {
      font-family: 'KenzMDM';
      src: url('../fonts/KENZ-MDM-BODY-R.ttf') format('truetype');
      font-weight: 400;
      font-style: normal;
      font-display: swap;
    }
    @font-face {
      font-family: 'KenzMDM';
      src: url('../fonts/KENZ-MDM-BODY-B.ttf') format('truetype');
      font-weight: 700;
      font-style: normal;
      font-display: swap;
    }
    /* KENZ Malayalam Font Family - Headline (titles) */
    @font-face {
      font-family: 'KenzMDM-HD';
      src: url('../fonts/KENZ-MDM-HD-Regular.ttf') format('truetype');
      font-weight: 400;
      font-style: normal;
      font-display: swap;
    }
    @font-face {
      font-family: 'KenzMDM-HD';
      src: url('../fonts/KENZ-MDM-HD-Bold.ttf') format('truetype');
      font-weight: 700;
      font-style: normal;
      font-display: swap;
    }

    :root {
      --forest:      #0C3528;
      --green:       #185C40;
      --green-mid:   #267A58;
      --green-light: #3DA06E;
      --gold:        #C8961E;
      --gold-light:  #F0B429;
      --gold-pale:   #FDE9A0;
      --cream:       #FEF9EE;
      --cream-dark:  #F5ECD5;
      --parchment:   #EDE0C0;
      --text:        #1A0E06;
      --text-mid:    #4A3520;
      --text-light:  #7A6248;
      --red:         #B91C1C;
      --red-lt:      #EF4444;
      --white:       #FFFEF8;
      --card:        #FFFDF4;
      --border:      #DDD0B0;
      --nav-h:       68px;
      --max-w:       1200px;
      --r:           12px;
      --r-lg:        20px;
      --sh-sm: 0 2px 10px rgba(12,53,40,.08);
      --sh-md: 0 6px 24px rgba(12,53,40,.14);
      --sh-lg: 0 12px 48px rgba(12,53,40,.20);
      --sh-gold: 0 4px 20px rgba(200,150,30,.30);
      /* Noto first = full Malayalam character coverage (chillus, vowel signs).
         KENZ kept as fallback for English / where it has glyphs.
         For UI elements that should use KENZ, --ui-serif / --ui-sans are applied explicitly. */
      --serif:    'Noto Serif Malayalam', 'Noto Serif', Georgia, serif;
      --sans:     'Noto Sans Malayalam', 'Noto Sans', system-ui, sans-serif;
      --ui-serif: 'KenzMDM-HD', 'Noto Serif Malayalam', Georgia, serif;
      --ui-sans:  'KenzMDM', 'Noto Sans Malayalam', system-ui, sans-serif;
    }
    *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      font-family:var(--serif);
      background:var(--cream);
      color:var(--text);
      min-height:100vh;
      overflow-x:hidden;
      -webkit-user-select:none;
      -moz-user-select:none;
      -ms-user-select:none;
      user-select:none;
    }
    img{max-width:100%;height:auto;display:block}
    a{text-decoration:none;color:inherit}
    button{cursor:pointer;border:none;background:none;font-family:inherit}
    input,textarea,select{font-family:inherit}
    input[type="password"] { font-family: system-ui, sans-serif; letter-spacing: 2px; }
    ul{list-style:none}
    ::-webkit-scrollbar{width:5px}
    ::-webkit-scrollbar-track{background:var(--cream-dark)}
    ::-webkit-scrollbar-thumb{background:var(--green-mid);border-radius:3px}

    /* ---- LOADING ---- */
    #ls{
      position:fixed;inset:0;background:var(--forest);
      display:flex;align-items:center;justify-content:center;
      flex-direction:column;gap:24px;z-index:9999;
      transition:opacity .5s,visibility .5s;
    }
    #ls.hide{opacity:0;visibility:hidden;pointer-events:none}
    .ll{
      font-family:var(--serif);font-size:2.4rem;font-weight:700;
      color:var(--gold-light);
      animation:pulse 1.6s ease-in-out infinite;
    }
    .ld{display:flex;gap:10px}
    .ld span{
      width:11px;height:11px;background:var(--gold);border-radius:50%;
      animation:ldot 1.2s ease-in-out infinite;
    }
    .ld span:nth-child(2){animation-delay:.2s}
    .ld span:nth-child(3){animation-delay:.4s}
    @keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
    @keyframes ldot{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

    /* ---- NAVBAR ---- */
    #nav{
      position:sticky;top:0;z-index:1000;
      background:var(--forest);height:var(--nav-h);
      border-bottom:3px solid var(--gold);
      box-shadow:0 4px 24px rgba(0,0,0,.35);
    }
    .ni{
      max-width:var(--max-w);margin:0 auto;padding:0 16px;
      height:100%;display:flex;align-items:center;justify-content:space-between;
      gap:12px;
    }
    .nlogo{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0}
    .nli{
      width:44px;height:44px;border-radius:10px;
      background:linear-gradient(135deg,var(--gold),var(--gold-light));
      display:flex;align-items:center;justify-content:center;
      font-size:1.5rem;box-shadow:var(--sh-gold);
    }
    .nlt{font-family:var(--ui-serif);font-size:1.45rem;font-weight:700;color:var(--gold-light)}
    .nls{font-size:.62rem;color:rgba(255,255,255,.45);font-family:var(--ui-sans);display:block;margin-top:-3px}
    .nlinks{display:flex;align-items:center;gap:3px;flex:1;justify-content:center;flex-wrap:wrap}
    .nl{
      padding:6px 13px;color:rgba(255,255,255,.78);font-size:.88rem;
      font-family:var(--sans);border-radius:20px;transition:all .2s;
      font-weight:500;cursor:pointer;white-space:nowrap;
    }
    .nl:hover{background:rgba(255,255,255,.10);color:var(--gold-light)}
    .nl.active{background:var(--gold);color:var(--forest);font-weight:700}
    .nadmin{
      padding:7px 16px;background:rgba(200,150,30,.18);color:var(--gold-light);
      border:1px solid var(--gold);border-radius:20px;font-size:.84rem;
      font-family:var(--sans);transition:all .2s;cursor:pointer;white-space:nowrap;flex-shrink:0;
    }
    .nadmin:hover{background:var(--gold);color:var(--forest)}
    .ham{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;flex-shrink:0}
    .ham span{display:block;width:24px;height:2px;background:var(--gold-light);border-radius:2px;transition:all .3s}

    #mmenu{
      display:none;position:fixed;top:var(--nav-h);left:0;right:0;
      background:var(--forest);border-bottom:2px solid var(--gold);
      padding:12px;z-index:999;flex-direction:column;gap:6px;
      box-shadow:0 10px 32px rgba(0,0,0,.4);
    }
    #mmenu.open{display:flex}
    .mnl{
      padding:11px 14px;color:rgba(255,255,255,.82);font-size:.96rem;
      font-family:var(--sans);border-radius:8px;cursor:pointer;transition:all .2s;
    }
    .mnl:hover,.mnl.active{background:rgba(200,150,30,.22);color:var(--gold-light)}

    /* ---- PAGES ---- */
    .page{display:none;animation:fi .35s ease}
    .page.active{display:block}
    @keyframes fi{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

    /* ---- HERO ---- */
    #hero{
      position:relative;min-height:72vh;
      background:linear-gradient(155deg,var(--forest) 0%,var(--green) 100%);
      overflow:hidden;display:flex;align-items:center;
    }
    .hbg{
      position:absolute;inset:0;
      background:
        radial-gradient(circle at 18% 50%,rgba(200,150,30,.09) 0%,transparent 50%),
        radial-gradient(circle at 82% 18%,rgba(200,150,30,.07) 0%,transparent 40%),
        url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    }
    .hcontent{
      max-width:var(--max-w);margin:0 auto;padding:56px 16px;
      width:100%;display:grid;grid-template-columns:1fr 1fr;
      gap:48px;align-items:center;position:relative;z-index:1;
    }
    .htag{
      display:inline-block;background:var(--gold);color:var(--forest);
      padding:4px 14px;border-radius:20px;font-size:.78rem;font-weight:700;
      font-family:var(--ui-sans);margin-bottom:14px;
    }
    .htext h1{
      font-size:clamp(1.7rem,3.8vw,2.8rem);font-weight:800;color:var(--white);
      line-height:1.35;margin-bottom:14px;
    }
    .htext p{
      font-size:.95rem;color:rgba(255,255,255,.72);line-height:1.85;
      margin-bottom:26px;font-family:var(--sans);
    }
    .hmeta{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap}
    .hmeta span{font-size:.8rem;color:rgba(255,255,255,.58);font-family:var(--sans)}
    .hmeta .dot{color:var(--gold)}
    .hbtn{
      display:inline-flex;align-items:center;gap:8px;
      background:var(--gold);color:var(--forest);
      padding:13px 28px;border-radius:30px;font-weight:700;
      font-family:var(--sans);font-size:.94rem;
      transition:all .3s;box-shadow:var(--sh-gold);
    }
    .hbtn:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(200,150,30,.45)}
    .himgw{position:relative}
    .himg{
      width:100%;height:420px;object-fit:cover;
      border-radius:var(--r-lg);box-shadow:0 20px 64px rgba(0,0,0,.45);
      border:3px solid rgba(200,150,30,.3);
    }
    .himo{
      position:absolute;bottom:0;left:0;right:0;height:42%;
      background:linear-gradient(to top,rgba(12,53,40,.65),transparent);
      border-radius:0 0 var(--r-lg) var(--r-lg);
    }

    /* ---- SEARCH ---- */
    .sbar{
      padding:22px 16px;
      background:var(--card);border-bottom:1px solid var(--border);
    }
    .sinn{max-width:580px;margin:0 auto;position:relative}
    .sinput{
      width:100%;padding:13px 20px 13px 48px;
      background:var(--cream);border:2px solid var(--border);
      border-radius:30px;font-size:.97rem;color:var(--text);
      outline:none;transition:border-color .2s;font-family:var(--sans);
    }
    .sinput:focus{border-color:var(--green-mid)}
    .sico{position:absolute;left:17px;top:50%;transform:translateY(-50%);font-size:1.1rem;color:var(--text-light)}

    /* ---- SECTION ---- */
    .sec{padding:36px 16px;max-width:var(--max-w);margin:0 auto}
    .sec-last{padding-bottom:64px}
    .sh{display:flex;align-items:center;gap:12px;margin-bottom:22px}
    .st{font-family:var(--ui-serif);font-size:1.35rem;font-weight:700;color:var(--green)}
    .sl{flex:1;height:2px;background:linear-gradient(to right,var(--gold),transparent)}

    /* ---- CATEGORY GRID ---- */
    .catgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:12px}
    .catpill{
      padding:14px 12px;background:var(--card);border:1px solid var(--border);
      border-radius:var(--r);text-align:center;cursor:pointer;
      transition:all .25s;box-shadow:var(--sh-sm);
    }
    .catpill:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--gold)}
    .cico{font-size:1.55rem;margin-bottom:6px}
    .cname{font-size:.82rem;font-weight:700;color:var(--text-mid);font-family:var(--sans)}
    .ccount{font-size:.72rem;color:var(--text-light);font-family:var(--sans)}

    /* ---- STORY GRID & CARD ---- */
    .sgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(295px,1fr));gap:22px}
    .scard{
      background:var(--card);border-radius:var(--r-lg);overflow:hidden;
      box-shadow:var(--sh-sm);border:1px solid var(--border);
      transition:all .3s;cursor:pointer;
    }
    .scard:hover{transform:translateY(-7px);box-shadow:var(--sh-lg);border-color:var(--gold)}
    .cimgw{position:relative;overflow:hidden;height:198px}
    .cimg{width:100%;height:100%;object-fit:cover;transition:transform .45s}
    .scard:hover .cimg{transform:scale(1.07)}
    .cimgf{
      width:100%;height:100%;
      background:linear-gradient(135deg,var(--green),var(--forest));
      display:flex;align-items:center;justify-content:center;font-size:3rem;
    }
    .cbadge{
      position:absolute;top:11px;left:11px;background:var(--gold);
      color:var(--forest);padding:3px 10px;border-radius:12px;
      font-size:.72rem;font-weight:700;font-family:var(--sans);
    }
    .cfbadge{
      position:absolute;top:11px;right:11px;
      background:linear-gradient(135deg,var(--gold),var(--gold-light));
      color:var(--forest);padding:3px 9px;border-radius:12px;
      font-size:.68rem;font-weight:700;font-family:var(--sans);
    }
    .cbody{padding:18px}
    .ctitle{
      font-size:1.06rem;font-weight:700;color:var(--text);
      margin-bottom:9px;line-height:1.42;
      display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
    }
    .cexc{
      font-size:.85rem;color:var(--text-light);line-height:1.72;
      margin-bottom:14px;font-family:var(--sans);
      display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
    }
    .cfoot{
      display:flex;align-items:center;justify-content:space-between;
      padding-top:13px;border-top:1px solid var(--border);
    }
    .cauthor{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-light);font-family:var(--sans)}
    .aav{
      width:26px;height:26px;border-radius:50%;
      background:linear-gradient(135deg,var(--green-mid),var(--green));
      display:flex;align-items:center;justify-content:center;
      font-size:.68rem;color:#fff;font-weight:700;
    }
    .cread{
      display:inline-flex;align-items:center;gap:4px;
      color:var(--green);font-size:.78rem;font-weight:700;
      font-family:var(--sans);transition:gap .2s;
    }
    .scard:hover .cread{gap:8px;color:var(--gold)}

    /* ---- STORY DETAIL PAGE ---- */
    #story-pg{max-width:780px;margin:0 auto;padding:0 16px 64px}
    .shero{
      margin:0 -16px;height:52vh;min-height:290px;
      position:relative;overflow:hidden;
    }
    .shero img{width:100%;height:100%;object-fit:cover}
    .sho{
      position:absolute;inset:0;
      background:linear-gradient(to bottom,rgba(0,0,0,.08) 0%,rgba(12,53,40,.72) 100%);
    }
    .shc{position:absolute;bottom:0;left:0;right:0;padding:28px 22px}
    .shccat{
      display:inline-block;background:var(--gold);color:var(--forest);
      padding:3px 12px;border-radius:12px;font-size:.78rem;font-weight:700;
      font-family:var(--sans);margin-bottom:9px;
    }
    .shc h1{font-size:clamp(1.35rem,3vw,2rem);color:#fff;font-weight:800;line-height:1.32}
    .s-nh{padding:36px 0 18px}
    .s-nh .shccat{
      display:inline-block;background:var(--gold);color:var(--forest);
      padding:4px 14px;border-radius:12px;font-size:.78rem;font-weight:700;
      font-family:var(--sans);margin-bottom:12px;
    }
    .s-nh h1{font-size:clamp(1.5rem,3.5vw,2.1rem);font-weight:800;color:var(--text);line-height:1.35}
    .smeta{
      display:flex;align-items:center;gap:18px;
      padding:14px 0;border-bottom:2px solid var(--border);
      margin-bottom:28px;flex-wrap:wrap;
    }
    .smi{display:flex;align-items:center;gap:6px;font-size:.83rem;color:var(--text-light);font-family:var(--sans)}
    .sbody{font-size:1.08rem;line-height:2.05;color:var(--text)}
    .sbody p{margin-bottom:22px}
    .back{
      display:inline-flex;align-items:center;gap:8px;
      padding:8px 0;color:var(--green);font-size:.9rem;
      font-family:var(--sans);font-weight:700;cursor:pointer;
      transition:all .2s;margin:14px 0;
    }
    .back:hover{gap:14px;color:var(--gold)}

    /* ---- CATEGORY PAGE ---- */
    #cat-pg{max-width:var(--max-w);margin:0 auto;padding:36px 16px 64px}
    .chero{
      background:linear-gradient(135deg,var(--forest),var(--green));
      border-radius:var(--r-lg);padding:36px 28px;margin-bottom:28px;
      position:relative;overflow:hidden;
    }
    .chero::before{
      content:'';position:absolute;right:-20px;top:-20px;
      width:180px;height:180px;border-radius:50%;
      background:rgba(200,150,30,.08);
    }
    .chero h2{font-size:1.75rem;font-weight:800;color:var(--gold-light);margin-bottom:5px}
    .chero p{color:rgba(255,255,255,.65);font-family:var(--sans);font-size:.88rem}

    /* ---- ADMIN LOGIN ---- */
    #al-pg{
      min-height:calc(100vh - var(--nav-h));
      display:flex;align-items:center;justify-content:center;padding:36px 16px;
    }
    .lcard{
      background:var(--card);border:1px solid var(--border);
      border-radius:var(--r-lg);padding:48px 38px;
      width:100%;max-width:410px;box-shadow:var(--sh-lg);
    }
    .lico{
      width:64px;height:64px;border-radius:16px;
      background:linear-gradient(135deg,var(--forest),var(--green));
      display:flex;align-items:center;justify-content:center;
      font-size:1.8rem;margin:0 auto 22px;
    }
    .ltitle{font-family:var(--ui-serif);text-align:center;font-size:1.38rem;font-weight:800;color:var(--text);margin-bottom:5px}
    .lsub{text-align:center;font-size:.84rem;color:var(--text-light);font-family:var(--sans);margin-bottom:28px}
    .fg{margin-bottom:18px}
    .fl{display:block;font-size:.83rem;font-weight:700;color:var(--text-mid);font-family:var(--sans);margin-bottom:7px}
    .fi{
      width:100%;padding:11px 15px;background:var(--cream);
      border:2px solid var(--border);border-radius:10px;
      font-size:.94rem;color:var(--text);transition:border-color .2s;outline:none;
    }
    .fi:focus{border-color:var(--green-mid)}
    .fta{min-height:175px;resize:vertical}
    .fsel{
      width:100%;padding:11px 40px 11px 15px;background:var(--cream);
      border:2px solid var(--border);border-radius:10px;
      font-size:.94rem;color:var(--text);outline:none;
      transition:border-color .2s;appearance:none;
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%234A3520' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
      background-repeat:no-repeat;background-position:right 14px center;
    }
    .fsel:focus{border-color:var(--green-mid)}
    .frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
    .fchk{display:flex;align-items:center;gap:10px}
    .fchk input{width:17px;height:17px;accent-color:var(--green)}
    .fchk label{font-size:.88rem;color:var(--text-mid);font-family:var(--sans)}
    .lerr{
      background:#FEE2E2;color:var(--red);padding:11px 14px;
      border-radius:8px;font-size:.83rem;font-family:var(--sans);
      margin-bottom:14px;display:none;
    }
    .lerr.show{display:block}
    .btnp{
      width:100%;padding:13px;
      background:linear-gradient(135deg,var(--green),var(--forest));
      color:#fff;border-radius:10px;font-size:.98rem;font-weight:700;
      font-family:var(--sans);transition:all .3s;
      box-shadow:0 4px 16px rgba(24,92,64,.32);
    }
    .btnp:hover{transform:translateY(-2px);box-shadow:0 7px 22px rgba(24,92,64,.42)}
    .btns{
      padding:8px 18px;background:transparent;color:var(--green);
      border:2px solid var(--green-mid);border-radius:8px;
      font-size:.85rem;font-weight:700;font-family:var(--sans);transition:all .2s;
    }
    .btns:hover{background:var(--green);color:#fff}
    .btnd{
      padding:8px 16px;background:transparent;color:var(--red);
      border:2px solid var(--red-lt);border-radius:8px;
      font-size:.85rem;font-weight:700;font-family:var(--sans);transition:all .2s;
    }
    .btnd:hover{background:var(--red);color:#fff}
    .btng{
      padding:10px 22px;
      background:linear-gradient(135deg,var(--gold),var(--gold-light));
      color:var(--forest);border-radius:8px;font-size:.88rem;
      font-weight:700;font-family:var(--sans);transition:all .2s;box-shadow:var(--sh-gold);
    }
    .btng:hover{transform:translateY(-2px)}

    /* ---- ADMIN DASH ---- */
    #adm-pg{max-width:var(--max-w);margin:0 auto;padding:28px 16px 64px}
    .aheader{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:14px}
    .atitle{font-family:var(--ui-serif);font-size:1.45rem;font-weight:800;color:var(--forest)}
    .asub{font-size:.83rem;color:var(--text-light);font-family:var(--sans)}
    .statgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:28px}
    .statcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--sh-sm)}
    .statcard .snum{font-size:1.9rem;font-weight:800;color:var(--green)}
    .statcard .slbl{font-size:.82rem;color:var(--text-light);font-family:var(--sans);margin-top:3px}
    .atabs{display:flex;gap:6px;margin-bottom:20px;border-bottom:2px solid var(--border);padding-bottom:0}
    .atab{
      padding:9px 18px;font-size:.88rem;font-weight:700;
      font-family:var(--sans);color:var(--text-light);
      border-radius:8px 8px 0 0;cursor:pointer;transition:all .2s;
      border-bottom:2px solid transparent;margin-bottom:-2px;
    }
    .atab.active{color:var(--green);border-bottom-color:var(--green);background:rgba(24,92,64,.07)}
    .tabc{display:none}.tabc.active{display:block}
    .atblw{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm)}
    .atbl{width:100%;border-collapse:collapse}
    .atbl th{background:var(--forest);color:var(--gold-light);padding:13px 14px;text-align:left;font-size:.82rem;font-family:var(--sans);font-weight:700}
    .atbl td{padding:13px 14px;border-bottom:1px solid var(--border);font-size:.84rem;font-family:var(--sans);color:var(--text-mid);vertical-align:middle}
    .atbl tr:last-child td{border-bottom:none}
    .atbl tr:hover td{background:var(--cream)}
    .tacts{display:flex;gap:7px;flex-wrap:wrap}
    .abtn{padding:5px 11px;border-radius:6px;font-size:.78rem;font-weight:700;font-family:var(--sans);transition:all .2s;cursor:pointer;border:1px solid}
    .aedit{color:var(--green);border-color:var(--green-mid);background:rgba(24,92,64,.07)}
    .aedit:hover{background:var(--green);color:#fff}
    .adel{color:var(--red);border-color:var(--red-lt);background:rgba(185,28,28,.07)}
    .adel:hover{background:var(--red);color:#fff}
    .tthumb{width:48px;height:36px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}
    .tnoi{width:48px;height:36px;background:var(--green-mid);border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem}

    /* ---- MODAL ---- */
    .movl{
      position:fixed;inset:0;background:rgba(0,0,0,.62);
      z-index:2000;display:none;align-items:flex-start;
      justify-content:center;padding:18px;overflow-y:auto;
    }
    .movl.open{display:flex}
    .modal{
      background:var(--card);border-radius:var(--r-lg);padding:28px;
      width:100%;max-width:660px;margin:auto;
      box-shadow:0 24px 64px rgba(0,0,0,.45);position:relative;
    }
    .mtitle{font-size:1.18rem;font-weight:800;color:var(--forest);margin-bottom:22px;display:flex;align-items:center;gap:10px}
    .mclose{
      position:absolute;top:14px;right:14px;width:32px;height:32px;
      border-radius:50%;background:var(--cream-dark);
      display:flex;align-items:center;justify-content:center;
      font-size:1.05rem;cursor:pointer;transition:background .2s;color:var(--text);
    }
    .mclose:hover{background:var(--parchment)}
    .macts{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}
    .imgpv{width:100%;height:150px;object-fit:cover;border-radius:8px;border:2px solid var(--border);margin-top:7px;display:none}
    .imgpv.show{display:block}

    /* ---- TOAST ---- */
    #tc{position:fixed;top:86px;right:14px;z-index:3000;display:flex;flex-direction:column;gap:7px}
    .toast{
      padding:13px 18px;background:var(--forest);color:#fff;
      border-radius:10px;font-size:.84rem;font-family:var(--sans);
      box-shadow:var(--sh-lg);border-left:4px solid var(--gold);
      animation:tsi .3s ease,tfo .38s ease 2.62s forwards;max-width:310px;
    }
    .toast.ok{border-left-color:#10B981}
    .toast.err{border-left-color:var(--red)}
    @keyframes tsi{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
    @keyframes tfo{from{opacity:1}to{opacity:0}}

    /* ---- EMPTY STATE ---- */
    .empty{text-align:center;padding:56px 18px}
    .empty .ei{font-size:2.8rem;margin-bottom:14px}
    .empty .et{font-size:1.05rem;font-weight:700;color:var(--text-mid);margin-bottom:6px}
    .empty .es{font-size:.83rem;color:var(--text-light);font-family:var(--sans)}

    /* ---- CONFIRM ---- */
    #confovl{position:fixed;inset:0;background:rgba(0,0,0,.62);z-index:4000;display:none;align-items:center;justify-content:center}
    #confovl.open{display:flex}
    .confbox{background:var(--card);border-radius:var(--r-lg);padding:30px;max-width:390px;width:90%;box-shadow:0 24px 64px rgba(0,0,0,.45);text-align:center}
    .confbox .ci{font-size:2.4rem;margin-bottom:14px}
    .confbox .ct{font-size:1.08rem;font-weight:800;color:var(--text);margin-bottom:7px}
    .confbox .cs{font-size:.84rem;color:var(--text-light);font-family:var(--sans);margin-bottom:22px}
    .confbtns{display:flex;gap:10px;justify-content:center}

    /* ---- FOOTER ---- */
    footer{background:var(--forest);color:rgba(255,255,255,.68);padding:40px 16px 22px;border-top:3px solid var(--gold);margin-top:auto}
    .fi2{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px}
    .fbrand .flogo{font-size:1.25rem;font-weight:800;color:var(--gold-light);margin-bottom:9px}
    .fbrand p{font-size:.83rem;line-height:1.72;font-family:var(--sans)}
    .fcol h4{font-size:.87rem;font-weight:700;color:var(--gold-light);margin-bottom:12px;font-family:var(--sans)}
    .fcol ul li{margin-bottom:7px}
    .fcol ul li span,.fcol ul li a{font-size:.82rem;color:rgba(255,255,255,.56);font-family:var(--sans);cursor:pointer;transition:color .2s}
    .fcol ul li span:hover,.fcol ul li a:hover{color:var(--gold-light)}
    .fbot{max-width:var(--max-w);margin:20px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:.78rem;font-family:var(--sans)}

    /* ---- DEMO BANNER ---- */
    #demo-banner{
      background:linear-gradient(135deg,#7C3AED,#4F46E5);
      color:#fff;padding:11px 16px;font-family:var(--sans);font-size:.85rem;
      text-align:center;display:none;
    }
    #demo-banner.show{display:block}

    /* ---- RESPONSIVE ---- */
    @media(max-width:768px){
      .nlinks{display:none}
      .ham{display:flex}
      .hcontent{grid-template-columns:1fr}
      .himg{height:260px}
      .sgrid{grid-template-columns:1fr}
      .frow{grid-template-columns:1fr}
      .fi2{grid-template-columns:1fr;gap:22px}
      .atbl{display:block;overflow-x:auto}
      .lcard{padding:28px 22px}
      .modal{padding:22px 14px}
      #hero{min-height:auto}
      .statgrid{grid-template-columns:1fr 1fr}
    }
    @media(max-width:480px){
      :root{--nav-h:60px}
      .nlt{font-size:1.18rem}
      .catgrid{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}
    }
