/* Constitution USA Tactical Supply - Complete Store Stylesheet */
:root{
  --navy:#0a1628;--navy-light:#12243d;--navy-mid:#1a3355;
  --gold:#c9a84c;--gold-light:#e2c97e;--gold-dark:#a8872e;
  --white:#f5f5f5;--gray:#b0b0b0;--dark:#0d0d0d;
  --red:#c0392b;--green:#27ae60;--blue:#2980b9;
  --card-bg:#141e30;--border:#1e3050;--text:#e0e0e0;
  --input-bg:#0f1923;--success:#2ecc71;--warning:#f39c12;
  --danger:#e74c3c;--radius:8px;--shadow:0 4px 20px rgba(0,0,0,.4);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--navy);color:var(--text);line-height:1.6;min-height:100vh}
a{color:var(--gold);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold-light)}
img{max-width:100%;height:auto}
button,input,select,textarea{font-family:inherit}

/* === HEADER === */
.site-header{background:linear-gradient(180deg,#060e1a,var(--navy));border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(8px)}
.header-top{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:12px 24px}
.logo{display:flex;align-items:center;gap:12px}
.logo img,.logo svg{height:40px;width:40px}
.logo-text{font-size:1.4rem;font-weight:700;color:var(--gold);letter-spacing:1px;text-transform:uppercase}
.logo-text span{color:var(--white);font-weight:400;display:block;font-size:.7rem;letter-spacing:3px}
.header-search{flex:1;max-width:500px;margin:0 32px;position:relative}
.header-search input{width:100%;padding:10px 44px 10px 16px;border-radius:24px;border:1px solid var(--border);background:var(--input-bg);color:var(--white);font-size:.95rem;outline:none;transition:border .2s}
.header-search input:focus{border-color:var(--gold)}
.header-search button{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:var(--gold);border:none;color:var(--navy);width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}
.header-actions{display:flex;align-items:center;gap:20px}
.header-actions a{color:var(--gray);font-size:.85rem;display:flex;align-items:center;gap:6px;transition:color .2s}
.header-actions a:hover{color:var(--gold)}
.cart-badge{position:relative}
.cart-count{position:absolute;top:-8px;right:-10px;background:var(--red);color:#fff;font-size:.65rem;min-width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}

/* Nav */
.site-nav{background:var(--navy-light);border-bottom:1px solid var(--border)}
.site-nav ul{display:flex;list-style:none;max-width:1400px;margin:0 auto;padding:0 24px;gap:0}
.site-nav a{display:block;padding:12px 20px;color:var(--gray);font-size:.9rem;font-weight:500;transition:all .2s;border-bottom:2px solid transparent}
.site-nav a:hover,.site-nav a.active{color:var(--gold);border-bottom-color:var(--gold)}

/* === HERO === */
.hero{background:linear-gradient(135deg,#0a1628 0%,#1a3355 50%,#0a1628 100%);padding:80px 24px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 0L60 30L30 60L0 30Z' fill='none' stroke='%23c9a84c' stroke-opacity='0.03' stroke-width='1'/%3E%3C/svg%3E");pointer-events:none}
.hero h1{font-size:3rem;font-weight:800;color:var(--white);margin-bottom:16px;text-transform:uppercase;letter-spacing:2px}
.hero h1 .gold{color:var(--gold)}
.hero p{font-size:1.2rem;color:var(--gray);max-width:600px;margin:0 auto 32px}
.hero-cta{display:inline-flex;gap:16px;flex-wrap:wrap;justify-content:center}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;border:none;text-transform:uppercase;letter-spacing:1px}
.btn-primary{background:var(--gold);color:var(--navy)}
.btn-primary:hover{background:var(--gold-light);color:var(--navy);transform:translateY(-1px);box-shadow:0 4px 16px rgba(201,168,76,.3)}
.btn-outline{background:transparent;border:2px solid var(--gold);color:var(--gold)}
.btn-outline:hover{background:var(--gold);color:var(--navy)}
.btn-danger{background:var(--danger);color:#fff}
.btn-sm{padding:8px 16px;font-size:.8rem}
.btn-lg{padding:16px 36px;font-size:1.05rem}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* === PRODUCT GRID === */
.section{max-width:1400px;margin:0 auto;padding:48px 24px}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px}
.section-title{font-size:1.8rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:1px}
.section-title::after{content:'';display:block;width:60px;height:3px;background:var(--gold);margin-top:8px}
.view-all{color:var(--gold);font-weight:600;font-size:.9rem}

.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.product-card{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;transition:all .3s;cursor:pointer;position:relative}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold-dark)}
.product-card .img-wrap{width:100%;aspect-ratio:1;overflow:hidden;background:linear-gradient(135deg,#1a2a3a,#0f1923);display:flex;align-items:center;justify-content:center;position:relative}
.product-card .img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.product-card:hover .img-wrap img{transform:scale(1.05)}
.img-fallback{display:flex!important;align-items:center;justify-content:center;width:100%;height:100%;font-size:1.1rem;color:var(--gold);font-weight:600;text-align:center;padding:20px;background:linear-gradient(135deg,#1a2a3a,#0f1923)!important}
.product-tags{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:6px;z-index:2}
.tag{padding:4px 10px;border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.tag-sale{background:var(--red);color:#fff}
.tag-new{background:var(--green);color:#fff}
.tag-best{background:var(--gold);color:var(--navy)}
.tag-top{background:var(--blue);color:#fff}
.tag-premium{background:#8e44ad;color:#fff}
.tag-budget{background:#16a085;color:#fff}
.tag-seasonal{background:#e67e22;color:#fff}
.product-info{padding:16px}
.product-name{font-size:1rem;font-weight:600;color:var(--white);margin-bottom:8px;line-height:1.3}
.product-rating{display:flex;align-items:center;gap:6px;margin-bottom:8px;font-size:.85rem}
.stars{color:var(--gold)}
.rating-count{color:var(--gray);font-size:.8rem}
.product-price{display:flex;align-items:center;gap:10px}
.price-current{font-size:1.25rem;font-weight:700;color:var(--gold)}
.price-original{font-size:.9rem;color:var(--gray);text-decoration:line-through}
.price-save{font-size:.75rem;color:var(--green);font-weight:600}
.stock-low{color:var(--warning);font-size:.8rem;margin-top:6px;font-weight:500}

/* === PRODUCT DETAIL === */
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:1200px;margin:40px auto;padding:0 24px}
.product-gallery{position:relative}
.product-gallery .main-image{width:100%;aspect-ratio:1;border-radius:var(--radius);overflow:hidden;background:var(--card-bg);border:1px solid var(--border)}
.product-gallery .main-image img{width:100%;height:100%;object-fit:cover}
.product-gallery .thumb-row{display:flex;gap:8px;margin-top:12px}
.product-gallery .thumb{width:80px;height:80px;border-radius:6px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:border .2s}
.product-gallery .thumb.active,.product-gallery .thumb:hover{border-color:var(--gold)}
.product-gallery .thumb img{width:100%;height:100%;object-fit:cover}
.product-details-panel h1{font-size:1.8rem;color:var(--white);margin-bottom:8px}
.product-details-panel .detail-price{font-size:2rem;color:var(--gold);font-weight:700;margin:16px 0}
.product-details-panel .detail-desc{color:var(--gray);line-height:1.7;margin-bottom:24px}
.size-selector{margin-bottom:24px}
.size-selector label{display:block;margin-bottom:8px;font-weight:600;color:var(--white);font-size:.9rem}
.size-options{display:flex;flex-wrap:wrap;gap:8px}
.size-btn{padding:8px 16px;border:1px solid var(--border);border-radius:6px;background:var(--input-bg);color:var(--text);cursor:pointer;transition:all .2s;font-size:.9rem}
.size-btn:hover{border-color:var(--gold);color:var(--gold)}
.size-btn.selected{background:var(--gold);color:var(--navy);border-color:var(--gold);font-weight:600}
.qty-row{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.qty-input{display:flex;align-items:center;border:1px solid var(--border);border-radius:6px;overflow:hidden}
.qty-input button{background:var(--navy-light);border:none;color:var(--gold);width:40px;height:40px;cursor:pointer;font-size:1.2rem}
.qty-input input{width:50px;text-align:center;border:none;background:var(--input-bg);color:var(--white);height:40px;font-size:1rem}
.feature-list{list-style:none;margin:24px 0}
.feature-list li{padding:6px 0;color:var(--text);font-size:.9rem;display:flex;align-items:flex-start;gap:8px}
.feature-list li::before{content:'✓';color:var(--gold);font-weight:700;flex-shrink:0}
.detail-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.meta-item{font-size:.85rem}
.meta-item span{color:var(--gray)}
.meta-item strong{color:var(--white);display:block}

/* Reviews Section */
.reviews-section{max-width:1200px;margin:48px auto;padding:0 24px}
.review-summary{display:flex;align-items:center;gap:32px;margin-bottom:32px;padding:24px;background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border)}
.review-avg{text-align:center;min-width:120px}
.review-avg .big-num{font-size:3rem;font-weight:700;color:var(--gold)}
.review-avg .big-stars{color:var(--gold);font-size:1.2rem}
.review-bars{flex:1}
.review-bar{display:flex;align-items:center;gap:10px;margin:4px 0;font-size:.85rem}
.review-bar .bar-track{flex:1;height:6px;background:var(--navy);border-radius:3px;overflow:hidden}
.review-bar .bar-fill{height:100%;background:var(--gold);border-radius:3px}
.review-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}
.review-card .review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.review-card .reviewer{font-weight:600;color:var(--white)}
.review-card .review-date{color:var(--gray);font-size:.8rem}
.review-card .review-stars{color:var(--gold);margin-bottom:8px}
.review-card .review-text{color:var(--text);line-height:1.6;font-size:.95rem}
.verified-badge{display:inline-flex;align-items:center;gap:4px;color:var(--green);font-size:.75rem;font-weight:600;margin-left:8px}

/* === CART === */
.cart-container{max-width:1000px;margin:40px auto;padding:0 24px}
.cart-item{display:flex;gap:20px;padding:20px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;align-items:center}
.cart-item img{width:100px;height:100px;object-fit:cover;border-radius:6px}
.cart-item-info{flex:1}
.cart-item-name{font-weight:600;color:var(--white);margin-bottom:4px}
.cart-item-size{color:var(--gray);font-size:.85rem}
.cart-item-price{font-size:1.1rem;font-weight:700;color:var(--gold);min-width:100px;text-align:right}
.cart-item .remove-btn{color:var(--gray);background:none;border:none;cursor:pointer;font-size:1.2rem;padding:4px 8px;transition:color .2s}
.cart-item .remove-btn:hover{color:var(--red)}
.cart-summary{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-top:24px}
.cart-summary-row{display:flex;justify-content:space-between;margin-bottom:12px;font-size:.95rem}
.cart-summary-row.total{font-size:1.3rem;font-weight:700;color:var(--gold);border-top:1px solid var(--border);padding-top:16px;margin-top:16px}
.empty-cart{text-align:center;padding:80px 24px;color:var(--gray)}
.empty-cart .icon{font-size:4rem;margin-bottom:16px}

/* === CHECKOUT === */
.checkout-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;max-width:1200px;margin:40px auto;padding:0 24px}
.checkout-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin-bottom:24px}
.checkout-section h2{font-size:1.2rem;color:var(--white);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-row.full{grid-template-columns:1fr}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.85rem;color:var(--gray);font-weight:500}
.form-group input,.form-group select{padding:10px 14px;border-radius:6px;border:1px solid var(--border);background:var(--input-bg);color:var(--white);font-size:.95rem;outline:none;transition:border .2s}
.form-group input:focus,.form-group select:focus{border-color:var(--gold)}
.form-group input::placeholder{color:#555}
.card-icons{display:flex;gap:8px;margin-bottom:12px}
.card-icons img,.card-icons span{height:28px;padding:2px 8px;background:var(--white);border-radius:4px;font-size:.7rem;color:#333;font-weight:700;display:flex;align-items:center}
.order-summary-side{position:sticky;top:80px}
.order-item{display:flex;gap:12px;margin-bottom:12px;align-items:center}
.order-item img{width:60px;height:60px;object-fit:cover;border-radius:4px}
.order-item-name{font-size:.85rem;color:var(--white);flex:1}
.order-item-price{font-size:.9rem;font-weight:600;color:var(--gold)}

/* Payment Processing Overlay */
.payment-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(10,22,40,.95);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999}
.payment-spinner{width:80px;height:80px;border:4px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:24px}
@keyframes spin{to{transform:rotate(360deg)}}
.payment-overlay h2{color:var(--white);margin-bottom:8px}
.payment-overlay p{color:var(--gray);font-size:.9rem}
.payment-steps{margin-top:32px;text-align:left}
.payment-step{padding:8px 0;color:var(--gray);font-size:.9rem;display:flex;align-items:center;gap:10px}
.payment-step.done{color:var(--green)}
.payment-step.active{color:var(--gold)}
.payment-step .step-icon{width:20px;text-align:center}

/* === EMPLOYEE PORTAL === */
.portal-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,var(--navy),#0d1b2a)}
.portal-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow)}
.portal-card h2{text-align:center;color:var(--white);margin-bottom:8px;font-size:1.4rem}
.portal-card .subtitle{text-align:center;color:var(--gray);font-size:.85rem;margin-bottom:28px}
.portal-tabs{display:flex;margin-bottom:24px;border-bottom:1px solid var(--border)}
.portal-tab{flex:1;padding:10px;text-align:center;cursor:pointer;color:var(--gray);font-weight:600;font-size:.9rem;border-bottom:2px solid transparent;transition:all .2s}
.portal-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.portal-input{width:100%;padding:12px 16px;border-radius:8px;border:1px solid var(--border);background:var(--input-bg);color:var(--white);font-size:.95rem;outline:none;margin-bottom:14px;transition:border .2s}
.portal-input:focus{border-color:var(--gold)}
.portal-input::placeholder{color:#555}
.portal-btn{width:100%;padding:14px;border:none;border-radius:8px;cursor:pointer;font-weight:700;font-size:1rem;text-transform:uppercase;letter-spacing:1px;margin-top:8px;transition:all .2s}
.portal-btn.login-btn{background:var(--gold);color:var(--navy)}
.portal-btn.login-btn:hover{background:var(--gold-light)}
.portal-btn.signup-btn{background:var(--green);color:#fff}
.portal-btn.signup-btn:hover{background:#2ecc71}
.portal-error{color:var(--red);font-size:.85rem;text-align:center;margin-top:12px;min-height:20px}
.portal-footer{text-align:center;margin-top:20px;font-size:.8rem;color:var(--gray)}

/* === FILTERS === */
.filter-bar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px;align-items:center}
.filter-btn{padding:8px 16px;border-radius:20px;border:1px solid var(--border);background:var(--card-bg);color:var(--gray);cursor:pointer;font-size:.85rem;transition:all .2s}
.filter-btn.active,.filter-btn:hover{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.sort-select{padding:8px 16px;border-radius:6px;border:1px solid var(--border);background:var(--input-bg);color:var(--white);font-size:.85rem;margin-left:auto;cursor:pointer}

/* === FOOTER === */
.site-footer{background:linear-gradient(180deg,var(--navy),#060e1a);border-top:1px solid var(--border);padding:48px 24px 24px;margin-top:64px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;max-width:1400px;margin:0 auto}
.footer-col h3{color:var(--gold);font-size:.9rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}
.footer-col p{color:var(--gray);font-size:.85rem;line-height:1.6}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:8px}
.footer-col a{color:var(--gray);font-size:.85rem;transition:color .2s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{max-width:1400px;margin:0 auto;padding-top:24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;color:var(--gray);font-size:.8rem;flex-wrap:wrap;gap:12px;margin-top:32px}

/* === BREADCRUMB === */
.breadcrumb{max-width:1400px;margin:0 auto;padding:16px 24px;font-size:.85rem}
.breadcrumb a{color:var(--gray)}
.breadcrumb span{color:var(--gold)}

/* === BANNER === */
.promo-banner{background:var(--gold);color:var(--navy);text-align:center;padding:8px;font-size:.85rem;font-weight:600}

/* === TRUST BADGES === */
.trust-row{display:flex;justify-content:center;gap:40px;padding:40px 24px;flex-wrap:wrap}
.trust-item{text-align:center;color:var(--gray);font-size:.85rem}
.trust-item .icon{font-size:2rem;display:block;margin-bottom:8px}
.trust-item strong{color:var(--white);display:block}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .product-detail{grid-template-columns:1fr}
  .checkout-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .header-top{flex-wrap:wrap;gap:12px}
  .header-search{order:3;max-width:100%;margin:0;flex-basis:100%}
  .hero h1{font-size:2rem}
  .product-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
  .site-nav ul{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .footer-grid{grid-template-columns:1fr}
  .review-summary{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .product-grid{grid-template-columns:1fr 1fr;gap:12px}
  .product-info{padding:10px}
  .product-name{font-size:.85rem}
  .hero h1{font-size:1.6rem}
}

/* === ANIMATIONS === */
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .4s ease-out}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.pulse{animation:pulse 1.5s ease-in-out infinite}

/* === SCROLLBAR === */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--navy)}
::-webkit-scrollbar-thumb{background:var(--navy-mid);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--gold-dark)}
