/* ============================================
   GTND - Global Tender Network
   Professional Enterprise Theme v4
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700;800&display=swap');

:root {
    /* Navy + Teal + Amber: enterprise procurement palette */
    --primary: #1565C0;
    --primary-dark: #0D47A1;
    --primary-darker: #0A3A85;
    --primary-light: #E3F2FD;
    --primary-50: #F0F7FF;
    --teal: #00838F;
    --teal-light: #E0F7FA;
    --amber: #E65100;
    --amber-light: #FFF3E0;
    --green: #2E7D32;
    --green-light: #E8F5E9;
    --red: #C62828;
    --red-light: #FFEBEE;

    --g50: #FAFAF9;
    --g100: #F2F2F0;
    --g150: #EAEAE7;
    --g200: #DDDDD8;
    --g300: #C4C4BC;
    --g400: #9E9E93;
    --g500: #6F6F66;
    --g600: #545449;
    --g700: #3D3D35;
    --g800: #272720;
    --g900: #171712;

    --font: 'Figtree', system-ui, -apple-system, sans-serif;
    --mono: 'SF Mono', 'Cascadia Mono', 'Consolas', monospace;
    --r: 4px;
    --r-lg: 6px;
    --r-xl: 8px;
    --border: #D6D6CE;
    --border-light: #E8E8E3;
    --container: 1200px;
    --header-h: 52px;
    --topbar-h: 30px;
    --t: 0.12s ease;
}

/* === Reset === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;min-width:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{font-family:var(--font);color:var(--g800);background:#F7F7F5;line-height:1.55;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip;width:100%}
img{max-width:100%;height:auto}
table{max-width:100%;overflow-x:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--primary-dark)}
.rtl{direction:rtl;text-align:right}
.rtl .header-inner,.rtl .topbar-inner{flex-direction:row-reverse}
.rtl .nav-main{flex-direction:row-reverse}

/* === Container === */
.container{max-width:var(--container);margin:0 auto;padding:0 1rem;width:100%}
.skip-link{position:absolute;top:-100%;left:0;padding:0.75rem;background:var(--primary);color:#fff;z-index:10000;font-size:13px}
.skip-link:focus{top:0}

/* === Top Bar === */
.topbar{
    background:#1A1A16;
    color:#A3A39A;
    font-size:12px;
    height:var(--topbar-h);
    display:flex;
    align-items:center;
    border-bottom:1px solid #2A2A24;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;width:100%}
.topbar-left{display:flex;align-items:center;gap:1rem}
.topbar-sep{opacity:0.3;font-size:10px}
.topbar-text strong{color:#D4D4CC;font-weight:600}
.topbar-right{display:flex;align-items:center;gap:0.75rem}

/* === Language Switcher === */
.lang-switcher{position:relative}
.lang-btn{
    background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.1);
    color:#A3A39A;
    padding:3px 8px;
    border-radius:3px;
    cursor:pointer;
    font-size:11px;
    display:flex;
    align-items:center;
    gap:4px;
    transition:var(--t);
    font-family:var(--font);
}
.lang-btn:hover{border-color:rgba(255,255,255,0.25);color:#D4D4CC}
.lang-menu{
    display:none;
    position:absolute;
    top:calc(100% + 4px);
    right:0;
    background:#fff;
    border:1px solid var(--border);
    border-radius:var(--r-lg);
    box-shadow:0 8px 24px rgba(0,0,0,0.12);
    padding:4px;
    min-width:170px;
    z-index:1000;
    max-height:360px;
    overflow-y:auto;
}
.lang-menu.show{display:block}
.lang-option{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:var(--r);color:var(--g700);font-size:13px;transition:var(--t)}
.lang-option:hover{background:var(--g50);color:var(--g900)}
.lang-option.active{background:var(--primary-light);color:var(--primary);font-weight:600}

/* === Header === */
.header{
    background:#fff;
    border-bottom:1px solid var(--border);
    position:sticky;
    top:0;
    z-index:100;
    height:var(--header-h);
    display:flex;
    align-items:center;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem}
.logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.logo-icon{flex-shrink:0;border-radius:4px!important}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-name{font-weight:800;font-size:16px;color:var(--primary-dark);letter-spacing:-0.04em}
.logo-sub{font-size:9.5px;color:var(--g400);font-weight:600;text-transform:uppercase;letter-spacing:0.08em}

/* === Navigation === */
.nav-main{display:flex;align-items:center;gap:1px}
.nav-link{
    padding:6px 12px;
    border-radius:var(--r);
    font-size:13px;
    font-weight:500;
    color:var(--g600);
    transition:var(--t);
    white-space:nowrap;
}
.nav-link:hover{color:var(--primary);background:var(--primary-50)}
.nav-link.active{color:var(--primary);font-weight:700;background:var(--primary-light)}
.header-actions{display:flex;align-items:center;gap:6px}
.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px}
.mobile-toggle span{display:block;width:18px;height:1.5px;background:var(--g700);margin:4px 0;border-radius:1px;transition:var(--t)}

/* === Buttons === */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:5px;
    padding:7px 14px;border-radius:var(--r);font-weight:600;font-size:13px;
    border:none;cursor:pointer;transition:var(--t);text-decoration:none;
    white-space:nowrap;font-family:var(--font);line-height:1.4;
    max-width:100%;overflow:hidden;text-overflow:ellipsis;
}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);color:#fff}
.btn-primary-sm{background:var(--primary);color:#fff;padding:5px 10px;font-size:12px;border-radius:var(--r);font-weight:600}
.btn-primary-sm:hover{background:var(--primary-dark);color:#fff}
.btn-secondary{background:var(--teal);color:#fff}
.btn-secondary:hover{background:#006064;color:#fff}
.btn-outline{border:1px solid var(--primary);color:var(--primary);background:transparent;padding:6px 13px}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-outline-sm{border:1px solid var(--border);color:var(--g600);background:#fff;padding:5px 10px;font-size:12px;border-radius:var(--r);font-weight:500}
.btn-outline-sm:hover{border-color:var(--primary);color:var(--primary)}
.btn-ghost{color:var(--g600);background:transparent;padding:5px 10px;font-size:13px;font-weight:500}
.btn-ghost:hover{color:var(--primary);background:var(--primary-50)}
.btn-accent{background:var(--green);color:#fff}
.btn-accent:hover{background:#1B5E20;color:#fff}
.btn-lg{padding:10px 22px;font-size:14px;border-radius:var(--r-lg)}
.btn-icon{width:34px;height:34px;padding:0;border-radius:50%}

/* === Hero Section === */
.hero{
    background:#0F1D2F;
    color:#fff;
    padding:3rem 0 2.5rem;
    position:relative;
    overflow:hidden;
}
.hero::before{
    content:'';position:absolute;inset:0;
    background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='g' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M60 0H0v60' fill='none' stroke='rgba(255,255,255,0.03)' stroke-width='0.5'/%3E%3C/pattern%3E%3C/defs%3E%3Crect fill='url(%23g)' width='100%25' height='100%25'/%3E%3C/svg%3E");
}
.hero .container{position:relative;z-index:1}
.hero-content{text-align:center;max-width:600px;margin:0 auto}
.hero h1{
    font-size:2rem;
    font-weight:800;
    letter-spacing:-0.03em;
    line-height:1.2;
    margin-bottom:0.6rem;
    color:#fff;
}
.hero p{
    font-size:14px;
    color:#8896A6;
    margin-bottom:1.5rem;
    max-width:480px;
    margin-left:auto;margin-right:auto;
    line-height:1.6;
}

/* Hero Search */
.hero-search{
    background:#fff;
    border:none;
    border-radius:var(--r-lg);
    padding:4px;
    max-width:560px;
    margin:0 auto 2rem;
    display:flex;
    box-shadow:0 2px 12px rgba(0,0,0,0.15);
}
.hero-search input{
    flex:1;background:transparent;border:none;color:var(--g800);
    padding:8px 12px;font-size:14px;outline:none;font-family:var(--font);
}
.hero-search input::placeholder{color:var(--g400)}
.hero-search button{
    background:var(--primary);color:#fff;border:none;
    padding:8px 20px;border-radius:var(--r);font-weight:600;
    cursor:pointer;transition:var(--t);font-size:13px;font-family:var(--font);
    white-space:nowrap;
}
.hero-search button:hover{background:var(--primary-dark)}

/* Hero Stats */
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0.75rem;max-width:520px;margin:0 auto}
.hero-stat{text-align:center;padding:8px 0;border-right:1px solid rgba(255,255,255,0.08)}
.hero-stat:last-child{border-right:none}
.hero-stat .num{font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:-0.03em}
.hero-stat .label{font-size:10px;color:#6B7B8D;margin-top:2px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em}

/* === Section === */
.section{padding:2.5rem 0}
.section-header{text-align:center;margin-bottom:2rem}
.section-header h2{font-size:1.4rem;font-weight:800;color:var(--g900);margin-bottom:0.3rem;letter-spacing:-0.02em}
.section-header p{color:var(--g500);font-size:14px}
.section-title{
    font-size:15px;font-weight:700;margin-bottom:1rem;
    display:flex;align-items:center;justify-content:space-between;
    color:var(--g800);letter-spacing:-0.01em;
    padding-bottom:8px;
    border-bottom:2px solid var(--g150);
}
.section-title a{font-size:12px;font-weight:600;color:var(--primary)}

/* === Categories Grid === */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
.cat-card{
    background:#fff;border:1px solid var(--border-light);border-radius:var(--r);
    padding:14px 10px;text-align:center;transition:var(--t);
    cursor:pointer;text-decoration:none;color:var(--g700);
}
.cat-card:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50)}
.cat-icon{font-size:1.4rem;margin-bottom:4px}
.cat-name{font-weight:600;font-size:12px;line-height:1.3}
.cat-count{font-size:11px;color:var(--g400);margin-top:2px}

/* === Tender Cards === */
.tender-grid{display:grid;gap:1px;background:var(--border-light);border:1px solid var(--border-light);border-radius:var(--r-lg);overflow:hidden}
.tender-card{
    background:#fff;
    padding:14px 16px;
    transition:var(--t);
    border-radius:0;
    border:none;
}
.tender-card:hover{background:var(--primary-50)}
.tender-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:5px}
.tender-card h3{font-size:13px;font-weight:600;color:var(--g800);line-height:1.45}
.tender-card h3 a{color:inherit}
.tender-card h3 a:hover{color:var(--primary)}
.tender-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:6px;font-size:12px;color:var(--g500)}
.tender-meta-item{display:flex;align-items:center;gap:3px}
.tender-badge{
    display:inline-flex;align-items:center;
    padding:2px 6px;border-radius:2px;
    font-size:10px;font-weight:700;
    letter-spacing:0.03em;text-transform:uppercase;
}
.badge-country{background:var(--primary-light);color:var(--primary)}
.badge-open{background:var(--green-light);color:var(--green)}
.badge-deadline{background:var(--amber-light);color:var(--amber)}
.badge-expired{background:var(--red-light);color:var(--red)}
.badge-verified{background:var(--green-light);color:var(--green)}
.tender-card-footer{
    display:flex;align-items:center;justify-content:space-between;
    padding-top:8px;border-top:1px solid var(--g100);margin-top:4px;
}
.tender-budget{font-size:14px;font-weight:700;color:var(--g900);letter-spacing:-0.01em}
.tender-budget small{font-weight:400;color:var(--g400);font-size:11px;margin-left:2px}
.tender-actions{display:flex;gap:4px}

/* === Supplier Cards === */
.supplier-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.supplier-card{background:#fff;border:1px solid var(--border-light);border-radius:var(--r-lg);padding:16px;transition:var(--t)}
.supplier-card:hover{border-color:var(--primary)}
.supplier-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.supplier-logo{
    width:42px;height:42px;border-radius:var(--r);
    background:var(--primary-light);
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:15px;color:var(--primary);flex-shrink:0;
}
.supplier-info h3{font-size:13px;font-weight:600;color:var(--g800)}
.supplier-info p{font-size:12px;color:var(--g500)}
.supplier-tags{display:flex;flex-wrap:wrap;gap:4px;margin:8px 0}
.tag{display:inline-flex;padding:2px 6px;border-radius:2px;font-size:10px;background:var(--g100);color:var(--g600);font-weight:500}
.supplier-card-footer{display:flex;justify-content:space-between;align-items:center}
.rating{display:flex;align-items:center;gap:3px;color:var(--amber);font-weight:700;font-size:13px}

/* === Filters Sidebar === */
.page-with-sidebar{display:grid;grid-template-columns:240px 1fr;gap:16px}
.sidebar{position:sticky;top:calc(var(--header-h) + 12px);height:fit-content}
.filter-group{background:#fff;border:1px solid var(--border-light);border-radius:var(--r-lg);padding:14px;margin-bottom:8px}
.filter-group h4{
    font-size:10px;font-weight:700;color:var(--g500);
    margin-bottom:8px;text-transform:uppercase;letter-spacing:0.08em;
}
.filter-input{
    width:100%;padding:6px 8px;border:1px solid var(--border);
    border-radius:var(--r);font-size:13px;outline:none;
    transition:var(--t);background:#fff;font-family:var(--font);
}
.filter-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(21,101,192,0.1)}
.filter-select{
    width:100%;padding:6px 8px;border:1px solid var(--border);
    border-radius:var(--r);font-size:13px;outline:none;
    background:#fff;cursor:pointer;font-family:var(--font);
}
.filter-checkbox{display:flex;align-items:center;gap:6px;margin-bottom:5px;cursor:pointer;font-size:13px;color:var(--g600)}
.filter-checkbox input{width:14px;height:14px;accent-color:var(--primary)}

/* === Pagination === */
.pagination{display:flex;justify-content:center;align-items:center;gap:3px;margin-top:1.25rem;padding:1rem 0}
.pagination a,.pagination span{
    padding:5px 10px;border-radius:var(--r);font-size:12px;font-weight:500;
    border:1px solid var(--border-light);color:var(--g600);transition:var(--t);
}
.pagination a:hover{background:var(--g50);color:var(--g900);border-color:var(--border)}
.pagination .active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* === Tender Detail === */
.tender-detail{max-width:860px}
.detail-header{margin-bottom:1.25rem}
.detail-header h1{font-size:1.35rem;font-weight:700;line-height:1.35;margin-bottom:8px;letter-spacing:-0.01em}
.detail-badges{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
.detail-summary{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1px;
    background:var(--border-light);border:1px solid var(--border-light);
    border-radius:var(--r-lg);overflow:hidden;margin-bottom:1.25rem;
}
.summary-item{background:#fff;padding:12px 14px}
.summary-item .label{font-size:10px;color:var(--g500);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:2px;font-weight:600}
.summary-item .value{font-size:14px;font-weight:600;color:var(--g800)}
.detail-section{background:#fff;border:1px solid var(--border-light);border-radius:var(--r-lg);padding:16px;margin-bottom:10px}
.detail-section h2{font-size:14px;font-weight:700;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--g100);color:var(--g800)}
.detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:1.25rem}

/* === Auth Pages === */
.auth-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--g50)}
.auth-card{background:#fff;border-radius:var(--r-xl);box-shadow:0 4px 16px rgba(0,0,0,0.06);border:1px solid var(--border-light);padding:28px;width:100%;max-width:400px}
.auth-card h1{font-size:1.2rem;font-weight:700;text-align:center;margin-bottom:1.5rem}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--g700);margin-bottom:4px}
.form-control{
    width:100%;padding:8px 10px;border:1px solid var(--border);
    border-radius:var(--r);font-size:14px;transition:var(--t);font-family:var(--font);
}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(21,101,192,0.1)}
.form-error{color:var(--red);font-size:12px;margin-bottom:10px;text-align:center;background:var(--red-light);padding:6px;border-radius:var(--r)}
.form-footer{text-align:center;margin-top:1rem;font-size:13px;color:var(--g500)}
.form-footer a{font-weight:600}
.role-select{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.role-option{text-align:center;padding:10px 6px;border:1.5px solid var(--g200);border-radius:var(--r);cursor:pointer;transition:var(--t);font-size:12px}
.role-option:hover{border-color:var(--primary-light)}
.role-option.selected,.role-option input:checked+.role-label{border-color:var(--primary);background:var(--primary-light)}
.role-option input{display:none}

/* === Pricing === */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;max-width:1000px;margin:0 auto}
.price-card{background:#fff;border:1.5px solid var(--border-light);border-radius:var(--r-xl);padding:24px;text-align:center;transition:var(--t)}
.price-card.featured{border-color:var(--primary);position:relative}
.price-card.featured::before{
    content:'Popular';position:absolute;top:-10px;left:50%;transform:translateX(-50%);
    background:var(--primary);color:#fff;padding:2px 12px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;
}
.price-card:hover{box-shadow:0 4px 12px rgba(0,0,0,0.06)}
.price-name{font-size:15px;font-weight:700;margin-bottom:10px;color:var(--g800)}
.price-amount{font-size:2.5rem;font-weight:800;color:var(--g900);letter-spacing:-0.04em}
.price-amount small{font-size:14px;font-weight:400;color:var(--g400)}
.price-features{list-style:none;margin:16px 0;text-align:left}
.price-features li{padding:5px 0;font-size:13px;color:var(--g600);display:flex;align-items:center;gap:6px}
.price-features li::before{content:'✓';color:var(--green);font-weight:700;font-size:12px}

/* === Footer === */
.footer{background:#1A1A16;color:#8C8C82;padding:2.5rem 0 1rem;font-size:13px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 2fr;gap:2rem;margin-bottom:2rem}
.footer-brand{}
.footer-desc{font-size:12px;line-height:1.7;color:#7A7A70}
.footer-links h4,.footer-newsletter h4{
    color:#D4D4CC;font-size:10px;margin-bottom:10px;
    text-transform:uppercase;letter-spacing:0.08em;font-weight:700;
}
.footer-links a{display:block;color:#8C8C82;font-size:12px;padding:3px 0;transition:color var(--t)}
.footer-links a:hover{color:#D4D4CC}
.newsletter-form{display:flex;gap:4px}
.newsletter-form input{
    flex:1;padding:7px 10px;border:1px solid #3D3D35;
    border-radius:var(--r);background:#272720;color:#D4D4CC;
    font-size:12px;font-family:var(--font);
}
.newsletter-form input::placeholder{color:#6F6F66}
.newsletter-form button{
    background:var(--primary);color:#fff;border:none;
    padding:7px 12px;border-radius:var(--r);font-weight:600;
    cursor:pointer;transition:var(--t);font-size:11px;font-family:var(--font);
}
.newsletter-form button:hover{background:var(--primary-dark)}
.footer-bottom{
    border-top:1px solid #2A2A24;padding-top:1rem;
    display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#6F6F66;
}
.footer-langs{display:flex;align-items:center;gap:4px}
.footer-langs a{font-size:14px;opacity:0.5;transition:var(--t)}
.footer-langs a:hover{opacity:1}
.footer-more-langs{background:#3D3D35;padding:2px 6px;border-radius:8px;font-size:10px;cursor:pointer;color:#8C8C82}

/* === Mobile Nav === */
.mobile-nav{
    display:none;position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(0,0,0,0.5);z-index:200;opacity:0;pointer-events:none;transition:opacity 0.2s;
}
.mobile-nav.show{display:block;opacity:1;pointer-events:all}
.mobile-nav-inner{
    position:absolute;top:0;right:0;width:260px;height:100%;
    background:#fff;padding:20px;overflow-y:auto;
    transform:translateX(100%);transition:transform 0.2s ease;
    box-shadow:-2px 0 16px rgba(0,0,0,0.1);
}
.mobile-nav.show .mobile-nav-inner{transform:translateX(0)}
.mobile-nav-inner a{display:block;padding:8px 0;font-size:14px;color:var(--g700);border-bottom:1px solid var(--g100)}
.mobile-nav-inner a:hover{color:var(--primary)}
.mobile-nav-inner hr{border:none;border-top:1px solid var(--g200);margin:4px 0}

/* === Page Content === */
.page-header{
    background:#0F1D2F;
    color:#fff;
    padding:1.5rem 0 1.25rem;
    border-bottom:3px solid var(--primary);
    word-wrap:break-word;overflow-wrap:break-word;
    width:100%;min-width:0;
}
.page-header h1{font-size:1.35rem;font-weight:700;margin-bottom:3px;letter-spacing:-0.01em;line-height:1.35}
.page-header p{color:#8896A6;font-size:13px}
.page-body{padding:1.25rem 0 3rem;width:100%}

/* Results bar */
.results-bar{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:10px;padding:8px 12px;
    background:#fff;border:1px solid var(--border-light);border-radius:var(--r);
}
.results-count{font-size:12px;color:var(--g500)}
.results-sort{display:flex;align-items:center;gap:5px}
.results-sort select{padding:4px 8px;border:1px solid var(--border);border-radius:var(--r);font-size:12px;font-family:var(--font)}

/* CTA */
.cta-section{
    background:#0F1D2F;color:#fff;padding:2.5rem 2rem;text-align:center;
    border-radius:var(--r-xl);margin:2rem 0;position:relative;overflow:hidden;
}
.cta-section::before{
    content:'';position:absolute;inset:0;
    background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='g' width='60' height='60' patternUnits='userSpaceOnUse'%3E%3Cpath d='M60 0H0v60' fill='none' stroke='rgba(255,255,255,0.03)' stroke-width='0.5'/%3E%3C/pattern%3E%3C/defs%3E%3Crect fill='url(%23g)' width='100%25' height='100%25'/%3E%3C/svg%3E");
}
.cta-section h2{font-size:1.4rem;font-weight:800;margin-bottom:8px;position:relative;letter-spacing:-0.02em}
.cta-section p{font-size:14px;color:#8896A6;margin-bottom:1.25rem;position:relative}
.cta-section .btn{background:#fff;color:var(--primary);font-weight:700;position:relative}
.cta-section .btn:hover{background:var(--g100)}

/* Trust */
.trust-bar{display:flex;justify-content:center;gap:2.5rem;padding:2rem 0;flex-wrap:wrap}
.trust-item{text-align:center}
.trust-icon{font-size:1.5rem;margin-bottom:4px}
.trust-label{font-size:12px;font-weight:600;color:var(--g600)}

/* === Responsive Layouts === */
.g-sidebar{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}
.g-sidebar>aside{position:sticky;top:calc(var(--header-h) + var(--topbar-h) + 12px)}
.g-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g-4col{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.g-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}

/* === Responsive === */

/* Tablet */
@media(max-width:1024px){
    .page-with-sidebar{grid-template-columns:1fr}
    .sidebar{position:static}
    .footer-grid{grid-template-columns:1fr 1fr}
    .g-sidebar{grid-template-columns:1fr}
    .g-sidebar>aside{position:static}
    .td-layout{grid-template-columns:1fr!important}
    .td-sidebar{position:static!important;order:-1}

    /* Override inline sidebar grids */
    .page-body [style*="grid-template-columns: 1fr 3"],
    .page-body [style*="grid-template-columns:1fr 3"],
    .page-body [style*="grid-template-columns: 2fr 1fr"],
    .page-body [style*="grid-template-columns:2fr 1fr"],
    main [style*="grid-template-columns: 1fr 3"],
    main [style*="grid-template-columns:1fr 3"],
    main [style*="grid-template-columns: 2fr 1fr"],
    main [style*="grid-template-columns:2fr 1fr"],
    .dash-grid{
        grid-template-columns:1fr!important
    }
    [style*="position: sticky"],
    [style*="position:sticky"]{
        position:static!important
    }
}

/* Mobile */
@media(max-width:768px){
    .nav-main{display:none}.mobile-toggle{display:block}
    .hero h1{font-size:1.5rem}.hero p{font-size:13px}.hero{padding:2rem 0 1.5rem}
    .hero-stats{grid-template-columns:repeat(2,1fr);gap:0}.hero-stat{padding:6px 0}
    .hero-search{flex-direction:column}.hero-search button{width:100%}
    .footer-grid{grid-template-columns:1fr;gap:1.25rem}
    .footer-bottom{flex-direction:column;gap:8px;text-align:center}
    .topbar-left{display:none}
    .tender-card-header{flex-direction:column}
    .supplier-grid{grid-template-columns:1fr}
    .pricing-grid{grid-template-columns:1fr}
    .detail-summary{grid-template-columns:repeat(2,1fr)}
    .detail-actions{flex-direction:column}
    .cat-grid{grid-template-columns:repeat(3,1fr)}
    .page-header{padding:1rem 0 0.75rem}
    .page-header h1{font-size:1.15rem;word-break:break-word}
    .g-2col{grid-template-columns:1fr}
    .g-4col{grid-template-columns:repeat(2,1fr)}
    .g-sidebar{grid-template-columns:1fr}
    .g-sidebar>aside{position:static}

    /* Override inline 2-col grids */
    [style*="grid-template-columns: 1fr 1fr"],
    [style*="grid-template-columns:1fr 1fr"],
    [style*="grid-template-columns: 1fr 3"],
    [style*="grid-template-columns:1fr 3"],
    [style*="grid-template-columns: 2fr 1fr"],
    [style*="grid-template-columns:2fr 1fr"],
    [style*="grid-template-columns: repeat(4"],
    [style*="grid-template-columns:repeat(4"]{
        grid-template-columns:1fr!important
    }

    /* Tender detail classes */
    .td-layout{grid-template-columns:1fr!important}
    .td-sidebar{position:static!important;order:-1}
    .td-meta-grid{grid-template-columns:1fr!important}
    .td-auth-grid{grid-template-columns:1fr!important}
    .td-actions{flex-direction:column!important}
    .td-actions .btn{flex:none!important;width:100%!important}
    .td-countdown .num{font-size:1.5rem}

    /* Dashboard */
    .dash-grid{grid-template-columns:1fr!important}
    .dash-stats{grid-template-columns:repeat(2,1fr)!important}

    /* Flex wrap */
    .supplier-card-top{flex-wrap:wrap}

    /* Tables scroll */
    .desc-content table{display:block!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch}
    .desc-content td,.desc-content th{white-space:normal!important;word-break:break-word}

    .container{padding:0 12px}
}

/* Small mobile */
@media(max-width:480px){
    .hero h1{font-size:1.3rem}.hero-stat .num{font-size:1.2rem}
    .section{padding:1.5rem 0}.detail-summary{grid-template-columns:1fr}
    .cat-grid{grid-template-columns:repeat(2,1fr)}
    .g-4col{grid-template-columns:1fr}
    .dash-stats{grid-template-columns:1fr!important}

    /* Auto-fill grids with large minimums */
    [style*="minmax(340px"],
    [style*="minmax(300px"],
    [style*="minmax(250px"]{
        grid-template-columns:1fr!important
    }

    .container{padding:0 10px}
}

/* === Animations === */
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeInUp 0.3s ease forwards}
.delay-1{animation-delay:0.05s}.delay-2{animation-delay:0.1s}.delay-3{animation-delay:0.15s}
.skeleton{background:linear-gradient(90deg,var(--g200) 25%,var(--g100) 50%,var(--g200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-text{height:12px;margin-bottom:6px}.skeleton-title{height:16px;width:60%;margin-bottom:10px}

/* Description content */
.desc-content{font-size:13px;line-height:1.75;color:var(--g600);word-wrap:break-word;overflow-wrap:break-word}
.desc-content p{margin-bottom:8px}
.desc-content b,.desc-content strong{color:var(--g800);font-weight:600}
.desc-content ul,.desc-content ol{padding-left:1.25rem;margin-bottom:8px}
.desc-content table{width:100%;border-collapse:collapse;font-size:12px;margin:8px 0;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.desc-content td,.desc-content th{border:1px solid var(--g200);padding:6px 8px;white-space:nowrap}
.desc-content th{background:var(--g50);font-weight:600;text-align:left}

/* Focus */
*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}

/* Print */
@media print{.topbar,.header,.footer,.hero-search,.detail-actions,.sidebar{display:none!important}.page-header{background:#fff!important;color:#000!important;border:none!important}body{background:#fff}}
