/* ========== FISH AUCTION - MAIN STYLESHEET ========== */
@import url('https://fonts.googleapis.com/css2?family=Kanit:wght@300;400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Kanit',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;line-height:1.6}
a{color:var(--primary);text-decoration:none;transition:all .3s}
a:hover{opacity:.85}
img{max-width:100%;height:auto}
.container{max-width:1280px;margin:0 auto;padding:0 1rem}

/* ========== HEADER ========== */
.main-header{position:sticky;top:0;z-index:100;background:rgba(10,10,26,.92);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.05);padding:.5rem 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--primary);text-decoration:none}
.logo i{font-size:1.8rem;animation:fishSwim 3s ease-in-out infinite}
@keyframes fishSwim{0%,100%{transform:translateX(0) rotate(0)}50%{transform:translateX(5px) rotate(5deg)}}
.main-nav{display:flex;align-items:center;gap:.5rem}
.nav-link{padding:.5rem .75rem;border-radius:8px;color:var(--text);font-weight:400;font-size:.9rem;transition:all .3s}
.nav-link:hover{background:rgba(255,255,255,.08);color:var(--primary)}
.nav-user{display:flex;align-items:center;gap:.5rem}
.hamburger{display:none;background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer}

.btn-notif{position:relative;background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer;padding:.5rem}
.notif-badge{position:absolute;top:0;right:0;background:var(--accent);color:#000;font-size:.65rem;padding:1px 5px;border-radius:50%;font-weight:700}
.notif-panel{position:absolute;top:100%;right:1rem;width:350px;max-height:400px;overflow-y:auto;background:var(--card);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.notif-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.05)}
.notif-list .notif-item{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:all .2s}
.notif-list .notif-item:hover{background:rgba(255,255,255,.05)}
.notif-list .notif-item.unread{border-left:3px solid var(--primary)}

.dropdown{position:relative}
.btn-user{background:none;border:1px solid rgba(255,255,255,.1);color:var(--text);padding:.4rem .8rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.85rem;display:flex;align-items:center;gap:.4rem;transition:all .3s}
.btn-user:hover{border-color:var(--primary);background:rgba(255,255,255,.05)}
.dropdown-menu{display:none;position:absolute;right:0;top:110%;background:var(--card);border:1px solid rgba(255,255,255,.1);border-radius:10px;min-width:180px;overflow:hidden;box-shadow:0 10px 40px rgba(0,0,0,.4)}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;color:var(--text);font-size:.85rem;transition:all .2s}
.dropdown-menu a:hover{background:rgba(255,255,255,.05);color:var(--primary)}

.announcement-bar{background:linear-gradient(90deg,var(--primary),var(--secondary));color:#fff;text-align:center;padding:.5rem;font-size:.85rem;font-weight:500}

/* ========== HERO ========== */
.hero{position:relative;padding:5rem 0 6rem;overflow:hidden;text-align:center}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,212,255,.08),rgba(124,58,237,.08));z-index:0}
.hero-bg::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 30% 50%,rgba(0,212,255,.1),transparent 60%),radial-gradient(ellipse at 70% 50%,rgba(124,58,237,.1),transparent 60%);animation:heroFloat 8s ease-in-out infinite}
@keyframes heroFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(2%,3%)}}
.hero-content{position:relative;z-index:1}
.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;margin-bottom:1rem;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-size:clamp(1rem,2.5vw,1.3rem);opacity:.8;margin-bottom:2rem}
.hero-stats{display:flex;justify-content:center;gap:3rem;margin-bottom:2rem}
.stat-item{text-align:center}
.stat-item span{display:block;font-size:2rem;font-weight:700;color:var(--primary)}
.stat-item label{font-size:.8rem;opacity:.6}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-wave{position:absolute;bottom:-2px;left:0;right:0;height:60px;background:var(--bg);clip-path:ellipse(60% 100% at 50% 100%)}

/* ========== BUTTONS ========== */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border:none;border-radius:10px;font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s;text-decoration:none}
.btn:hover{transform:translateY(-2px);box-shadow:0 5px 20px rgba(0,0,0,.3)}
.btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}
.btn-accent{background:linear-gradient(135deg,var(--accent),#e67e22);color:#000}
.btn-sm{padding:.35rem .8rem;font-size:.8rem}
.btn-lg{padding:.75rem 1.5rem;font-size:1rem}
.btn-full{width:100%;justify-content:center}
.btn-icon{background:none;border:1px solid rgba(255,255,255,.1);color:var(--text);width:36px;height:36px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}
.btn-icon:hover{background:rgba(255,255,255,.1)}
.btn-icon.danger{color:#ef4444;border-color:rgba(239,68,68,.3)}
.btn-icon.danger:hover{background:rgba(239,68,68,.1)}
.btn-icon.success{color:#22c55e;border-color:rgba(34,197,94,.3)}
.btn-icon.primary{color:var(--primary);border-color:rgba(0,212,255,.3)}

/* ========== SECTIONS ========== */
.section{padding:3rem 0}
.section-title{font-size:1.8rem;font-weight:600;margin-bottom:2rem;display:flex;align-items:center;gap:.5rem}
.section-title i{color:var(--primary)}

/* ========== CATEGORIES ========== */
.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}
.category-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:1rem;text-align:center;cursor:pointer;transition:all .3s;color:var(--text);font-size:.85rem}
.category-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 5px 20px rgba(0,212,255,.15)}
.category-card i{display:block;font-size:1.5rem;margin-bottom:.3rem;color:var(--primary)}

/* ========== FILTER BAR ========== */
.filter-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2rem;align-items:center}
.search-box{position:relative;flex:1;min-width:200px}
.search-box i{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--primary);opacity:.6}
.search-box input{width:100%;background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.65rem 1rem .65rem 2.5rem;color:var(--text);font-family:inherit;font-size:.9rem;transition:all .3s}
.search-box input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 15px rgba(0,212,255,.15)}
.filter-group{display:flex;gap:.5rem;flex-wrap:wrap}
.filter-group select,.filter-bar select{background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.55rem .75rem;color:var(--text);font-family:inherit;font-size:.85rem;cursor:pointer}
.filter-group select:focus{outline:none;border-color:var(--primary)}

/* ========== AUCTION GRID ========== */
.auction-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.auction-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .4s;position:relative}
.auction-card:hover{transform:translateY(-5px);border-color:var(--primary);box-shadow:0 10px 40px rgba(0,212,255,.12)}
.auction-image{position:relative;aspect-ratio:4/3;overflow:hidden;background:rgba(0,0,0,.3)}
.auction-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.auction-card:hover .auction-image img{transform:scale(1.05)}
.no-image{display:flex;align-items:center;justify-content:center;height:100%;color:var(--primary);font-size:3rem;opacity:.3}
.auction-badge{position:absolute;top:.75rem;left:.75rem;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;backdrop-filter:blur(10px)}
.auction-badge.active{background:rgba(239,68,68,.85);color:#fff;animation:livePulse 2s infinite}
.auction-badge.upcoming{background:rgba(245,158,11,.85);color:#000}
.auction-badge.ended{background:rgba(34,197,94,.85);color:#fff}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{box-shadow:0 0 0 8px rgba(239,68,68,0)}}
.free-shipping-badge{position:absolute;top:.75rem;right:.75rem;background:rgba(34,197,94,.85);color:#fff;padding:.2rem .6rem;border-radius:20px;font-size:.7rem;font-weight:600;backdrop-filter:blur(10px)}
.auction-info{padding:1rem}
.auction-lot{font-size:.75rem;color:var(--primary);opacity:.7;font-weight:500}
.auction-title{font-size:1rem;font-weight:500;margin:.25rem 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.auction-species{font-size:.8rem;opacity:.6;margin-bottom:.5rem}
.auction-price{margin:.5rem 0}
.price-label{font-size:.75rem;opacity:.5;display:block}
.price-value{font-size:1.3rem;font-weight:700;color:var(--accent)}
.auction-meta{display:flex;justify-content:space-between;font-size:.8rem;opacity:.7;margin-top:.5rem}
.countdown{font-weight:500;color:var(--accent)}

/* ========== AUCTION DETAIL ========== */
.auction-detail-page{padding:2rem 0}
.back-link{display:inline-flex;align-items:center;gap:.3rem;margin-bottom:1.5rem;font-size:.9rem;opacity:.7}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.detail-images{position:sticky;top:5rem}
.main-image{position:relative;border-radius:16px;overflow:hidden;cursor:zoom-in;aspect-ratio:4/3;background:rgba(0,0,0,.3)}
.main-image img{width:100%;height:100%;object-fit:cover}
.image-zoom{position:absolute;bottom:1rem;right:1rem;background:rgba(0,0,0,.5);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s}
.main-image:hover .image-zoom{opacity:1}
.image-thumbs{display:flex;gap:.5rem;margin-top:.75rem;overflow-x:auto;padding:.25rem 0}
.image-thumbs .thumb{width:70px;height:70px;object-fit:cover;border-radius:10px;border:2px solid transparent;cursor:pointer;opacity:.6;transition:all .3s}
.image-thumbs .thumb.active,.image-thumbs .thumb:hover{border-color:var(--primary);opacity:1}
.detail-badge{display:inline-block;padding:.3rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;margin-bottom:.5rem}
.detail-badge.active{background:rgba(239,68,68,.2);color:#ef4444}
.detail-badge.upcoming{background:rgba(245,158,11,.2);color:#f59e0b}
.detail-badge.ended{background:rgba(34,197,94,.2);color:#22c55e}
.detail-lot{font-size:.85rem;color:var(--primary);opacity:.7}
.detail-title{font-size:1.8rem;font-weight:600;margin:.5rem 0 1rem}
.fish-specs{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1.5rem}
.spec{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:rgba(255,255,255,.03);border-radius:10px;font-size:.85rem}
.spec i{color:var(--primary);width:20px;text-align:center}
.spec label{opacity:.6;margin-right:.25rem}
.detail-desc{margin-bottom:1.5rem;padding:1rem;background:rgba(255,255,255,.03);border-radius:12px}
.detail-desc h3{font-size:1rem;margin-bottom:.5rem}
.detail-desc p{font-size:.9rem;opacity:.8;white-space:pre-wrap}

.bid-section{background:linear-gradient(135deg,rgba(0,212,255,.05),rgba(124,58,237,.05));border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem}
.price-display{display:flex;gap:1.5rem;margin-bottom:1rem}
.starting-price,.current-price{flex:1}
.starting-price label,.current-price label{display:block;font-size:.8rem;opacity:.5}
.starting-price span{font-size:1.1rem;opacity:.6}
.current-price span{font-size:1.8rem;font-weight:700;color:var(--accent)}
.bid-stats{display:flex;gap:1rem;margin-bottom:1rem;font-size:.85rem;opacity:.7}
.countdown-display{text-align:center;margin:1rem 0}
.countdown-label{font-size:.85rem;opacity:.6;margin-bottom:.5rem}
.countdown-timer{display:flex;justify-content:center;gap:.5rem}
.cd-unit{text-align:center;background:rgba(0,0,0,.3);border-radius:10px;padding:.5rem .75rem;min-width:55px}
.cd-unit span{display:block;font-size:1.5rem;font-weight:700;color:var(--primary)}
.cd-unit label{font-size:.65rem;opacity:.5}
.bid-form{margin-top:1rem}
.bid-input-group{display:flex;align-items:center;gap:0;margin-bottom:.5rem}
.bid-currency{background:rgba(255,255,255,.05);padding:.7rem 1rem;border-radius:10px 0 0 10px;font-weight:600;font-size:1.1rem;color:var(--accent)}
.bid-input{flex:1;background:var(--card);border:1px solid rgba(255,255,255,.1);border-left:none;border-radius:0 10px 10px 0;padding:.7rem 1rem;color:var(--text);font-family:inherit;font-size:1.1rem}
.bid-input:focus{outline:none;border-color:var(--primary)}
.bid-min{font-size:.8rem;opacity:.6;margin-bottom:.75rem}
.btn-bid{width:100%;font-size:1.1rem;padding:.8rem;animation:bidBounce 2s infinite}
@keyframes bidBounce{0%,100%{transform:translateY(0)}5%{transform:translateY(-3px)}10%{transform:translateY(0)}}
.winner-display{text-align:center;padding:1rem;background:linear-gradient(135deg,rgba(245,158,11,.1),rgba(234,179,8,.1));border:1px solid rgba(245,158,11,.3);border-radius:12px;font-size:1.2rem;font-weight:600;color:var(--accent)}
.live-pulse{color:#ef4444;animation:livePulse 1s infinite}

.bid-history{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:1.5rem}
.bid-history h3{margin-bottom:1rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}
.bid-item{display:flex;align-items:center;gap:.75rem;padding:.6rem;border-radius:8px;margin-bottom:.3rem;font-size:.85rem;transition:all .3s}
.bid-item.top{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.15)}
.bid-item.new-bid{animation:fadeHighlight 1s ease}
@keyframes fadeHighlight{0%{background:rgba(0,212,255,.2)}100%{background:transparent}}
.bid-rank{font-weight:700;min-width:30px}
.bid-user{flex:1;opacity:.7}
.bid-amount{font-weight:600;color:var(--accent)}
.bid-time{opacity:.4;font-size:.75rem}
.empty-bids{text-align:center;opacity:.4;padding:1rem}

/* ========== IMAGE MODAL ========== */
.image-modal{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s}
.image-modal.active{opacity:1;visibility:visible}
.image-modal img{max-width:90%;max-height:90vh;object-fit:contain;border-radius:8px}
.modal-close{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.1);border:none;color:#fff;width:44px;height:44px;border-radius:50%;font-size:1.2rem;cursor:pointer;z-index:10}
.modal-prev,.modal-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;width:50px;height:50px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .2s;z-index:10}
.modal-prev{left:1rem}
.modal-next{right:1rem}
.modal-prev:hover,.modal-next:hover{background:rgba(255,255,255,.2)}
.modal-counter{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);color:#fff;font-size:.9rem;opacity:.7}

/* ========== POPUP ========== */
.popup-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s}
.popup-overlay.active{opacity:1;visibility:visible}
.popup-content{background:var(--card);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;max-width:400px;text-align:center;position:relative;animation:popIn .3s ease}
@keyframes popIn{from{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}
.popup-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer}
.popup-content h3{font-size:1.3rem;margin-bottom:.5rem}
.popup-content p{opacity:.7;margin-bottom:1.5rem}
.popup-actions{display:flex;gap:.75rem;justify-content:center}

/* ========== AUTH PAGES ========== */
.auth-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:2rem}
.auth-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:20px;padding:2rem;width:100%;max-width:420px}
.auth-card-wide{max-width:700px}
.auth-card h2{text-align:center;margin-bottom:1.5rem;font-size:1.5rem}
.auth-link{text-align:center;margin-top:1rem;font-size:.9rem;opacity:.7}

/* ========== FORMS ========== */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.85rem;margin-bottom:.3rem;opacity:.8}
.form-group input,.form-group select,.form-group textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.6rem .85rem;color:var(--text);font-family:inherit;font-size:.9rem;transition:all .3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 10px rgba(0,212,255,.1)}
.form-group textarea{resize:vertical}
.form-group small{display:block;margin-top:.25rem;font-size:.75rem;opacity:.5}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.form-section-title{font-size:1rem;margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:.5rem}

/* ========== PAYMENT ========== */
.payment-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.payment-summary,.bank-info,.shipping-info{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:1.5rem}
.payment-summary h3,.bank-info h3,.shipping-info h3{margin-bottom:1rem;font-size:1.1rem;display:flex;align-items:center;gap:.5rem}
.summary-item{display:flex;justify-content:space-between;padding:.4rem 0;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.03)}
.summary-total{display:flex;justify-content:space-between;padding:.75rem 0;font-size:1.2rem;font-weight:700;color:var(--accent);border-top:2px solid rgba(255,255,255,.1);margin-top:.5rem}
.payment-deadline{margin-top:1rem;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:10px;padding:.75rem;text-align:center;font-size:.9rem}
.pay-countdown{display:inline;font-weight:700;color:var(--accent)}
.bank-detail{text-align:center;padding:1rem}
.bank-logo{margin-bottom:.5rem}
.account-number{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:.75rem 0;font-size:1.5rem;font-weight:700;letter-spacing:2px}
.btn-copy{background:var(--primary);color:#fff;border:none;padding:.3rem .8rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.8rem;transition:all .2s}
.btn-copy:hover{transform:scale(1.05)}
.account-name{font-size:1rem;opacity:.8;margin-bottom:.5rem}
.transfer-amount{font-size:1.1rem;color:var(--accent);margin-top:.5rem}
.upload-area{position:relative;border:2px dashed rgba(255,255,255,.15);border-radius:16px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s;margin-bottom:1rem}
.upload-area:hover{border-color:var(--primary)}
.upload-area input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-placeholder{opacity:.5}
.upload-placeholder i{color:var(--primary);margin-bottom:.5rem}
.slip-preview{max-width:100%;max-height:300px;border-radius:10px;object-fit:contain}
.submitted-slip{max-width:200px;border-radius:10px;margin-top:.5rem}
.status-badge{display:inline-block;padding:.5rem 1rem;border-radius:10px;font-weight:600}
.status-badge.submitted{background:rgba(245,158,11,.15);color:#f59e0b}
.status-badge.confirmed{background:rgba(34,197,94,.15);color:#22c55e}
.status-badge.shipped{background:rgba(59,130,246,.15);color:#3b82f6}
.status-badge.completed{background:rgba(34,197,94,.15);color:#22c55e}

/* ========== CARDS ========== */
.card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:1.25rem;margin-bottom:1rem;transition:all .3s;cursor:pointer}
.card:hover{border-color:var(--primary);box-shadow:0 5px 20px rgba(0,212,255,.08)}
.card-row{display:flex;gap:1rem;align-items:center}
.card-thumb{width:100px;height:100px;object-fit:cover;border-radius:12px;flex-shrink:0}
.card-thumb-placeholder{width:100px;height:100px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.05);border-radius:12px;color:var(--primary);font-size:2rem}
.card-info{flex:1}
.card-lot{font-size:.75rem;color:var(--primary);opacity:.7}
.card-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;font-size:.8rem}
.card-actions{margin-top:.75rem;display:flex;gap:.5rem}
.badge{display:inline-block;padding:.15rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500}
.badge.active{background:rgba(239,68,68,.15);color:#ef4444}
.badge.upcoming{background:rgba(245,158,11,.15);color:#f59e0b}
.badge.ended,.badge.completed{background:rgba(34,197,94,.15);color:#22c55e}
.badge.pending,.badge.submitted{background:rgba(245,158,11,.15);color:#f59e0b}
.badge.shipped{background:rgba(59,130,246,.15);color:#3b82f6}
.badge.pending_payment{background:rgba(239,68,68,.15);color:#ef4444}

/* ========== REVIEWS CAROUSEL ========== */
.reviews-section{background:linear-gradient(135deg,rgba(0,212,255,.03),rgba(124,58,237,.03))}
.review-carousel{overflow:hidden;position:relative}
.review-track{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:1rem .5rem;-ms-overflow-style:none;scrollbar-width:none}
.review-track::-webkit-scrollbar{display:none}
.review-card{flex-shrink:0;width:300px;background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:1.25rem;scroll-snap-align:start;transition:all .3s}
.review-card:hover{border-color:var(--primary);transform:translateY(-3px)}
.review-img{width:100%;height:180px;object-fit:cover;border-radius:10px;margin-bottom:.75rem}
.review-stars{color:#f59e0b;font-size:1rem;margin-bottom:.5rem}
.review-text{font-size:.85rem;opacity:.8;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.review-author{font-size:.8rem;opacity:.5;display:flex;align-items:center;gap:.3rem}

/* ========== PAGE CONTAINERS ========== */
.page-container{max-width:900px;margin:0 auto;padding:2rem 1rem}
.page-title{font-size:1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}
.profile-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:1.5rem}

/* ========== PAGINATION ========== */
.pagination{display:flex;justify-content:center;gap:.5rem;margin-top:2rem}
.page-btn{background:var(--card);border:1px solid rgba(255,255,255,.08);color:var(--text);padding:.4rem .8rem;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}
.page-btn.active,.page-btn:hover{background:var(--primary);color:#000;border-color:var(--primary)}

/* ========== FOOTER ========== */
.main-footer{background:rgba(0,0,0,.3);border-top:1px solid rgba(255,255,255,.05);padding:3rem 0 1.5rem;margin-top:3rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-grid h3,.footer-grid h4{margin-bottom:.75rem;color:var(--primary)}
.footer-grid a{display:block;color:var(--text);opacity:.6;margin-bottom:.3rem;font-size:.9rem;transition:all .2s}
.footer-grid a:hover{opacity:1;color:var(--primary)}
.footer-grid p{font-size:.85rem;opacity:.6}
.footer-bottom{text-align:center;opacity:.4;font-size:.8rem;border-top:1px solid rgba(255,255,255,.05);padding-top:1rem}

/* ========== LOADING & EMPTY ========== */
.loading-spinner{text-align:center;padding:3rem;font-size:1.2rem;opacity:.5}
.empty-state{text-align:center;padding:3rem;opacity:.4}
.empty-state i{font-size:3rem;margin-bottom:1rem;display:block}

/* ========== TOAST ========== */
.toast-container{position:fixed;top:5rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}
.toast{padding:.75rem 1.25rem;border-radius:12px;font-size:.9rem;font-weight:500;backdrop-filter:blur(10px);animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards;max-width:350px;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.toast.success{background:rgba(34,197,94,.9);color:#fff}
.toast.error{background:rgba(239,68,68,.9);color:#fff}
.toast.info{background:rgba(59,130,246,.9);color:#fff}
.toast.warning{background:rgba(245,158,11,.9);color:#000}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes toastOut{to{transform:translateX(100%);opacity:0}}

/* ========== ANIMATIONS ========== */
.animate-in{animation:fadeInUp .6s ease forwards}
.delay-1{animation-delay:.1s}
.delay-2{animation-delay:.2s}
.delay-3{animation-delay:.3s}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-scroll{opacity:0;transform:translateY(30px);transition:all .6s ease}
.animate-scroll.visible{opacity:1;transform:translateY(0)}
.animate-scroll.delay-0{transition-delay:0s}
.animate-scroll.delay-1{transition-delay:.1s}
.animate-scroll.delay-2{transition-delay:.2s}
.animate-scroll.delay-3{transition-delay:.3s}

/* ========== WATCHLIST BUTTON ========== */
.btn-watchlist{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:var(--text);padding:.4rem .8rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.85rem;transition:all .3s}
.btn-watchlist:hover{border-color:#ec4899;color:#ec4899;background:rgba(236,72,153,.1)}
.btn-watchlist.watched{background:rgba(236,72,153,.15);border-color:#ec4899;color:#ec4899}
.btn-watchlist.watched .fa-heart{color:#ec4899}

/* Featured Auctions */
.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.2rem;margin-bottom:1rem}
.featured-card{border:2px solid rgba(245,158,11,.35);box-shadow:0 0 20px rgba(245,158,11,.1)}
.featured-card:hover{border-color:rgba(245,158,11,.6);box-shadow:0 0 30px rgba(245,158,11,.2)}
.featured-star{position:absolute;top:8px;right:8px;font-size:1.4rem;filter:drop-shadow(0 0 4px rgba(245,158,11,.6))}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
  .detail-grid{grid-template-columns:1fr}
  .detail-images{position:static}
  .payment-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--card);padding:1rem;flex-direction:column;border-bottom:1px solid rgba(255,255,255,.05)}
  .main-nav.active{display:flex}
  .hamburger{display:block}
  .hero-stats{gap:1.5rem}
  .stat-item span{font-size:1.5rem}
  .fish-specs{grid-template-columns:1fr}
  .categories-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}
  .auction-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .auction-grid{grid-template-columns:1fr}
  .hero-title{font-size:1.8rem}
  .hero-stats{gap:1rem}
  .cd-unit{min-width:45px;padding:.3rem .5rem}
  .cd-unit span{font-size:1.2rem}
  .payment-grid{grid-template-columns:1fr}
  .card-row{flex-direction:column;text-align:center}
}

/* ========== MODAL ========== */
.modal{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s}
.modal.active{opacity:1;visibility:visible}
.modal-content{background:var(--card);border-radius:16px;padding:2rem;max-width:500px;width:90%;position:relative}
.modal .modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer}
