/* ==========================================================================
   ProHost Client Portal — Style v4
   Theme: Crisp Professional Light
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Source+Sans+3:ital,wght@0,300;0,400;0,600;1,300&display=swap');

/* ==========================================================================
   Variables
   ========================================================================== */
:root {
  --navy:       #0f3d0f;
  --navy-2:     #1a5c1a;
  --navy-3:     #236b23;
  --accent:     #2d8a2d;
  --accent-2:   #1e6b1e;
  --accent-dim: rgba(45,138,45,.1);
  --green:      #2d8a2d;
  --red:        #ef4444;
  --orange:     #f59e0b;
  --bg:         #f8fafc;
  --bg-2:       #ffffff;
  --bg-3:       #f1f5f9;
  --border:     #e2e8f0;
  --border-2:   #cbd5e1;
  --text:       #0f172a;
  --text-2:     #475569;
  --text-3:     #94a3b8;
  --r:          8px;
  --r-lg:       12px;
  --sh:         0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.06);
  --sh-lg:      0 8px 40px rgba(0,0,0,.12);
  --font:       'Source Sans 3',-apple-system,sans-serif;
  --display:    'Outfit',-apple-system,sans-serif;
  --t:          .18s ease;
}

/* ==========================================================================
   Reset
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{overflow-y:scroll;overflow-x:hidden;scroll-behavior:smooth;scrollbar-gutter:stable}
body{
  font-family:var(--font);font-size:16px;line-height:1.6;
  color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;margin:0;padding:0;
  display:grid;grid-template-rows:auto 1fr auto;min-height:100vh;overflow-x:hidden;
}
a{color:var(--accent-2);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--navy)}
p{margin:0;line-height:1.6}
h1,h2,h3,h4,h5,h6{font-family:var(--display);font-weight:600;color:var(--navy);margin:0;line-height:1.2}
ul,ol{margin:0;padding:0;list-style:none}
img{display:block;max-width:100%}
input,textarea,select,button{font-family:var(--font);font-size:16px}
input:focus,textarea:focus,select:focus{outline:none}
input[type=text],input[type=email],input[type=password],input[type=search]{-webkit-appearance:none}
small{font-size:13px;color:var(--text-3);display:block;margin-top:4px}
.visually-hidden{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  padding:0!important;
  margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
}

/* ==========================================================================
   Foundation grid compat
   ========================================================================== */
.row{width:100%;margin:0;padding:0}
.row::before,.row::after{content:'';display:table;clear:both}
.twelve.columns{width:100%;float:none;margin:0;padding:0}
.eight.columns{width:66.66%;float:left;padding:0 8px}
.six.columns{width:50%;float:left;padding:0 8px}
.four.columns{width:33.33%;float:left;padding:0 8px}
.three.columns{width:25%;float:left;padding:0 8px}
.two.columns{width:16.66%;float:left;padding:0 8px}
.columns,.column{float:left;padding:0 8px}
.row .row{max-width:100%;min-width:0}
.centered{float:none;margin:0 auto}

/* ==========================================================================
   Utilities
   ========================================================================== */
.cf::after{content:'';display:table;clear:both}
.vam{vertical-align:middle}.tac{text-align:center}.tar{text-align:right}
.sepH_a{margin-bottom:5px}.sepH_b{margin-bottom:12px}.sepH_c{margin-bottom:24px}
.sepV_a{margin-right:5px}.sepV_b{margin-right:10px}.sepV_c{margin-right:20px}
.sepH_a_line{padding-bottom:8px;margin-bottom:20px;border-bottom:1px solid var(--border)}
.sepH_no{margin-bottom:0}.small{font-size:13px}.medium{font-size:15px}.large{font-size:18px}

/* ==========================================================================
   Container
   ========================================================================== */
.container{max-width:1100px;width:100%;margin:0 auto;padding:0 24px;box-sizing:border-box}
.container>.row{padding-top:32px;padding-bottom:32px}

/* ==========================================================================
   HEADER — deep navy with subtle diagonal stripe texture
   ========================================================================== */
header{
  width:100%;max-width:100vw;overflow:hidden;
  background:var(--navy);
  background-image:
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 12px,
      rgba(255,255,255,.02) 12px,
      rgba(255,255,255,.02) 24px
    );
  position:sticky;top:0;z-index:200;
  box-shadow:0 2px 20px rgba(0,0,0,.2);
}

.container.head_s_a{padding-top:0!important;padding-bottom:0!important}
.container.head_s_a>.row{padding:0;display:flex;align-items:center;width:100%;gap:16px}
.container.head_s_a>.row.sepH_b{margin:0;padding:0}
.container.head_s_a .twelve.columns{flex:1 1 auto;min-width:0;width:auto;padding:0;margin-bottom:0}

/* Logo area */
#logo{display:inline-flex;align-items:center;gap:10px;padding:14px 0;text-decoration:none}
#logo img{height:28px;width:auto;padding:0!important;filter:brightness(0) invert(1)}
#logo::after{
  content:'ProHost';
  font-family:var(--display);
  font-size:20px;font-weight:700;
  color:#fff;letter-spacing:0;
}

/* Hamburger */
.nav-toggle-cb{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;appearance:none;-webkit-appearance:none}
.nav-toggle{
  display:none;position:absolute;top:50%;right:16px;transform:translateY(-50%);
  width:42px;height:42px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  border-radius:var(--r);cursor:pointer;
  color:#fff;font-size:20px;line-height:42px;text-align:center;
  user-select:none;-webkit-user-select:none;
  transition:background var(--t);z-index:201;
}
.nav-toggle:hover{background:rgba(255,255,255,.2)}

/* ==========================================================================
   NAVIGATION
   ========================================================================== */
#smoothmenu_h{
  background:none!important;border:none!important;border-radius:0!important;width:100%;
  position:relative;z-index:190;
}
#smoothmenu_h ul{
  display:flex!important;flex-direction:row!important;align-items:center!important;
  gap:0!important;margin:0!important;padding:0!important;list-style:none!important;
}
#smoothmenu_h ul li{position:relative;display:block!important;float:none!important}
#smoothmenu_h ul li:last-child{margin-left:auto}
#smoothmenu_h ul li>a{
  display:flex!important;align-items:center;
  padding:16px 16px!important;
  font-family:var(--display);font-size:14px!important;font-weight:500;
  color:rgba(255,255,255,.75)!important;
  border:none!important;text-shadow:none!important;
  white-space:nowrap;line-height:1!important;
  transition:color var(--t),background var(--t);
  border-bottom:3px solid transparent;
  margin-bottom:-3px;
}
#smoothmenu_h ul li>a:hover,
#smoothmenu_h ul li>a.selected{
  color:#fff!important;
  border-bottom-color:var(--accent)!important;
  text-decoration:none!important;
  background:rgba(255,255,255,.05)!important;
}
#smoothmenu_h ul li:last-child>a{
  color:rgba(255,255,255,.5)!important;
}
#smoothmenu_h ul li:last-child>a:hover{
  color:rgba(255,255,255,.85)!important;
  border-bottom-color:rgba(255,255,255,.3)!important;
}
/* Kill old nav junk */
.downarrowclass,.rightarrowclass,.ddshadow,.toplevelshadow,.tinynav{display:none!important}

/* ==========================================================================
   BOX — card component
   ========================================================================== */
.box_c{
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  margin-bottom:24px;
  box-shadow:var(--sh);
  transition:box-shadow var(--t);
}

.box_c_heading{
  display:flex;align-items:center;
  min-height:52px;padding:0 20px;gap:12px;
  flex-wrap:wrap;
  background:var(--bg-2);
  border-bottom:1px solid var(--border);
}

.box_c_heading .box_c_ico{
  width:32px;height:32px;border-radius:8px;
  background:var(--accent-dim);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;overflow:hidden;
}
.box_c_heading .box_c_ico img{
  width:16px;height:16px;
  filter:brightness(0) saturate(100%) invert(46%) sepia(98%) saturate(400%) hue-rotate(175deg);
}

.box_c_heading p{
  font-family:var(--display)!important;
  font-size:16px!important;font-weight:600!important;
  color:var(--navy)!important;
  padding-left:0!important;float:none!important;
  margin-bottom:0!important;line-height:1!important;
  flex:1;
}

.box_c_content{padding:24px;background:transparent;border:none}
.cntn_noP{padding:0!important}

/* ==========================================================================
   BUTTONS
   ========================================================================== */
.gh_button{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 16px;font-size:14px;font-weight:600;
  font-family:var(--display);
  color:var(--text-2);
  background:var(--bg-3);
  border:1px solid var(--border-2);
  border-radius:var(--r);cursor:pointer;
  text-decoration:none;white-space:nowrap;
  transition:background var(--t),color var(--t),border-color var(--t),box-shadow var(--t);
}
.gh_button:hover,.gh_button:focus{
  background:var(--accent-dim);
  border-color:var(--accent);
  color:var(--accent-2);
  text-decoration:none;
  box-shadow:0 0 0 3px rgba(45,138,45,.15);
}
.gh_button:active{transform:translateY(1px)}
.gh_button+.gh_button{margin-left:6px}

/* Icons */
.gh_button.icon::before{
  content:'';width:14px;height:14px;
  background:url(../img/ico/gh-icons.png) 0 99px no-repeat;
  background-size:24px auto;
  display:block;flex-shrink:0;
  filter:brightness(0) saturate(100%) invert(46%) sepia(10%) saturate(600%) hue-rotate(182deg);
  transition:filter var(--t);
}
.gh_button:hover::before,.gh_button:focus::before{
  filter:brightness(0) saturate(100%) invert(46%) sepia(98%) saturate(400%) hue-rotate(175deg);
}
.gh_button.log.icon::before{background-position:0 -72px}
.gh_button.mail.icon::before{background-position:0 -240px}
.gh_button.edit.icon::before{background-position:0 -264px}
.gh_button.trash.icon::before{background-position:0 -336px}
.gh_button.add.icon::before{background-position:0 -288px}
.gh_button.approve.icon::before{background-position:0 -48px}
.gh_button.loop.icon::before{background-position:0 -216px}
.gh_button.move.icon::before{background-position:0 -252px}

/* Primary button */
.gh_button.primary,input[type=submit],input[type=button],.button.white.small.radius.nice{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;font-weight:600;
  font-family:var(--display);
}
.gh_button.primary:hover,input[type=submit]:hover,input[type=button]:hover,.button.white.small.radius.nice:hover{
  background:var(--navy-2);
  border-color:var(--navy-2);
  color:#fff;
  box-shadow:0 4px 12px rgba(15,32,64,.25);
}
.gh_button.danger{
  background:linear-gradient(135deg,#ef4444,#dc2626);
  border-color:#dc2626;
  color:#fff;
}
.gh_button.danger:hover,.gh_button.danger:focus{
  background:linear-gradient(135deg,#dc2626,#b91c1c);
  border-color:#b91c1c;
  color:#fff;
  box-shadow:0 4px 12px rgba(220,38,38,.25);
}

input[type=submit],input[type=button]{
  border:none;border-radius:var(--r);
  padding:10px 24px;font-size:15px;cursor:pointer;
  letter-spacing:.2px;transition:background var(--t),box-shadow var(--t);
}

.button.white.small.radius.nice{
  display:inline-flex;align-items:center;
  padding:8px 18px;font-size:14px;border-radius:var(--r);cursor:pointer;
  transition:background var(--t),box-shadow var(--t);
}

/* ==========================================================================
   FORMS
   ========================================================================== */
.form_a{background:transparent;padding:0}
.form_a form{padding:0}
.form_a small{display:block}

.formRow{padding:16px 24px;border-bottom:1px solid var(--border)}
.formRow:last-child{border-bottom:none}

label{
  display:block;font-size:13px;font-weight:600;
  color:var(--text-2);margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.5px;
}
label+input.input-text,label+textarea,label+select{margin-top:0}

input.input-text,
input[type=text],input[type=email],input[type=password]{
  display:block;width:100%;
  background:#fff;
  border:1.5px solid var(--border-2);
  border-radius:var(--r);
  color:var(--text);
  padding:10px 14px;font-size:15px;font-family:var(--font);
  line-height:1.4;box-shadow:none;
  transition:border-color var(--t),box-shadow var(--t);
}
input.input-text:focus,
input[type=text]:focus,input[type=email]:focus,input[type=password]:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(45,138,45,.15);
}
input[disabled]{opacity:.45;cursor:not-allowed;background:var(--bg-3)}

select{
  display:block;width:100%;
  background:#fff;border:1.5px solid var(--border-2);border-radius:var(--r);
  color:var(--text);padding:10px 36px 10px 14px;font-size:15px;font-family:var(--font);
  cursor:pointer;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
  transition:border-color var(--t),box-shadow var(--t);
}
select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,138,45,.15);outline:none}
textarea{height:120px;resize:vertical;width:100%;background:#fff;border:1.5px solid var(--border-2);border-radius:var(--r);color:var(--text);padding:10px 14px;font-size:15px;font-family:var(--font);transition:border-color var(--t),box-shadow var(--t)}
textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,138,45,.15);outline:none}

label.error{color:var(--red)!important;font-size:12px;text-transform:none;letter-spacing:0;margin-top:4px}
.form-field.error input,.form-field.error textarea{border-color:var(--red)!important}

/* ==========================================================================
   LOGIN PAGE — centered card with branding
   ========================================================================== */
/* ==========================================================================
   LOGIN PAGE — detected by presence of .login_form
   ========================================================================== */
body:has(.login_form),
body.auth-screen{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 50%,#0c3460 100%)!important;
  display:flex!important;flex-direction:column;
  align-items:center;justify-content:center;
}
body:has(.login_form) header,
body.auth-screen header{ display:none; }
body:has(.login_form) #footer,
body.auth-screen #footer{ display:none!important; }

body:has(.login_form) .container,
body.auth-screen .container{
  width:100%;max-width:500px;
  padding:32px 24px;
}
body:has(.login_form) .row,
body:has(.login_form) .twelve.columns,
body.auth-screen .row,
body.auth-screen .twelve.columns{
  width:100%!important;float:none!important;
  padding:0!important;margin:0!important;
}

/* ProHost title above card */
body:has(.login_form) > .container:not(#footer)::before,
body.auth-screen > .container:not(#footer)::before{
  content:'ProHost';
  display:block;
  font-family:var(--display);font-size:32px;font-weight:700;
  color:#fff;text-align:center;margin-bottom:24px;letter-spacing:0;
}


/* Card */
body:has(.login_form) .box_c,
body.auth-screen .box_c{
  border:none;border-radius:16px;
  box-shadow:0 24px 80px rgba(0,0,0,.4);
  overflow:hidden;
}

/* Heading */
body:has(.login_form) .box_c_heading,
body.auth-screen .box_c_heading{
  background:var(--navy);border-bottom:none;
  padding:20px 28px;
}
body:has(.login_form) .box_c_heading p,
body.auth-screen .box_c_heading p{color:#fff!important;font-size:18px!important}
body:has(.login_form) .box_c_heading .box_c_ico,
body.auth-screen .box_c_heading .box_c_ico{background:rgba(255,255,255,.15)}
body:has(.login_form) .box_c_heading .box_c_ico img,
body.auth-screen .box_c_heading .box_c_ico img{filter:brightness(0) invert(1)}

/* Content */
body:has(.login_form) .box_c_content,
body.auth-screen .box_c_content{padding:28px}
body:has(.login_form) .box_c_content .row,
body.auth-screen .box_c_content .row{width:100%!important}
body:has(.login_form) .box_c_content .columns,
body:has(.login_form) .box_c_content .column,
body.auth-screen .box_c_content .columns,
body.auth-screen .box_c_content .column{
  width:100%!important;float:none!important;padding:0!important;margin-bottom:16px;
}

/* Submit */
body:has(.login_form) input[type=submit],
body.auth-screen input[type=submit]{
  width:100%;padding:13px;font-size:16px;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);
  color:#fff;border-radius:var(--r);font-family:var(--display);font-weight:700;
  letter-spacing:.3px;box-shadow:0 4px 20px rgba(45,138,45,.35);
}
body:has(.login_form) input[type=submit]:hover,
body.auth-screen input[type=submit]:hover{
  transform:translateY(-2px);box-shadow:0 8px 28px rgba(45,138,45,.45);
}
/* Inputs */
body:has(.login_form) input[type=text],
body:has(.login_form) input[type=password],
body.auth-screen input[type=text],
body.auth-screen input[type=password],
body.auth-screen input[type=email]{padding:12px 16px;font-size:16px}

/* Error row */
body:has(.login_form) .formRow:first-child,
body.auth-screen .formRow:first-child{border-bottom:none;padding:0 0 8px}

.auth-lang-wrap{
  position:fixed;
  top:14px;
  right:16px;
  z-index:500;
}
.auth-lang-wrap .lang-select{
  background:rgba(255,255,255,.13);
  border-color:rgba(255,255,255,.28);
  box-shadow:0 10px 30px rgba(0,0,0,.16);
}
.auth-flow-copy{
  text-align:center;
  max-width:420px;
  margin:0 auto 22px;
}
.auth-flow-copy h2{
  color:var(--navy);
  font-size:24px;
  margin:0 0 10px;
}
.auth-flow-copy p{
  color:var(--text-2);
  font-size:15px;
  margin-bottom:8px;
}
.auth-flow-form{
  max-width:420px;
  margin:0 auto;
}
.auth-flow-form label{
  display:block;
  margin-bottom:6px;
}
.auth-flow-form input[type=text],
.auth-flow-form input[type=password],
.auth-flow-form input[type=email]{
  margin-bottom:14px;
}

/* ==========================================================================
   DOMAINS TABLE
   ========================================================================== */
table.display{width:100%;border-collapse:collapse;font-size:15px}
table.display thead tr{border-bottom:2px solid var(--border)}
table.display thead th{
  padding:12px 16px;text-align:left;
  font-family:var(--display);font-size:12px;font-weight:600;
  letter-spacing:.8px;text-transform:uppercase;
  color:var(--text-3);white-space:nowrap;background:transparent;
}
table.display thead th.center{text-align:center}
table.display tbody tr{border-bottom:1px solid var(--border);transition:background var(--t)}
table.display tbody tr:last-child{border-bottom:none}
table.display tbody tr:hover{background:var(--bg-3)}
table.display tbody tr.odd{background:transparent}
table.display tbody tr.odd:hover{background:var(--bg-3)}
table.display tbody td{padding:14px 16px;color:var(--text);vertical-align:middle}
table.display tbody td.center{text-align:center}
table.display tbody td.center .gh_button{margin:0 2px}

/* Domain name styling */
table.display tbody td:nth-child(2){
  font-family:var(--display);font-weight:600;font-size:15px;color:var(--navy);
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
#footer{
  background:var(--navy);
  color:rgba(255,255,255,.4);
  font-size:13px;text-align:center;
  padding:13px 24px;margin-top:0;height:auto;border-top:none;
  letter-spacing:.3px;
}
footer.container#footer{max-width:100%;width:100%;border-radius:0}
#footer>.row{padding:0!important}

/* ==========================================================================
   MISC
   ========================================================================== */
.lbl{display:inline-block;padding:3px 10px;font-size:12px;font-weight:600;border-radius:50em;letter-spacing:.3px;text-transform:uppercase}
.ok_bg{background:#dcfce7;color:#166534}
.alert_bg{background:#fef3c7;color:#92400e}
.info_bg{background:#dbeafe;color:#1e40af}
.error_bg{background:#fee2e2;color:#991b1b}
.neutral_bg{background:var(--bg-3);color:var(--text-3)}

.alert-box{padding:14px 18px;border-radius:var(--r);font-size:14px;margin-bottom:16px;border:1px solid transparent}
.alert-box.info{background:#dbeafe;border-color:#93c5fd;color:#1e40af}
.alert-box.success{background:#dcfce7;border-color:#86efac;color:#166534}
.alert-box.warning{background:#fef3c7;border-color:#fde68a;color:#92400e}
.alert-box.error{background:#fee2e2;border-color:#fca5a5;color:#991b1b}

/* Success message */
.bold-title{font-family:var(--display);font-size:13px!important;font-weight:700!important;text-transform:uppercase;letter-spacing:.8px;color:var(--text-3)!important;margin-bottom:12px}
.editcontact{margin-top:12px}
.form_a label{margin-bottom:4px!important}
.editcontact input[type=submit]{width:100%!important;box-sizing:border-box}
.form_a .input-text,.admin-contact .input-text,.tech-contact .input-text,.nameservers .input-text{width:100%!important;max-width:100%!important;box-sizing:border-box!important;display:block!important}
.admin-contact input,.tech-contact input,.nameservers input{width:100%!important;max-width:100%!important;box-sizing:border-box!important}
.admin-contact,.tech-contact{float:left;width:50%;padding-right:20px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border);box-sizing:border-box}
.admin-contact .columns,.tech-contact .columns,.nameservers .columns,.ns-left .columns,.ns-right .columns{padding-left:0!important;padding-right:0!important;width:100%!important;float:none!important}
.nameservers{clear:both;width:100%;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.notification{overflow:hidden;width:100%;box-sizing:border-box}
.ns-left{float:left;width:50%;padding-right:16px}.ns-right{float:left;width:50%}
.notif{background:#fef3c7;border:1px solid #fde68a;border-radius:var(--r);padding:16px 20px;margin-top:16px;clear:both;width:100%;color:#78350f;line-height:1.75;box-sizing:border-box}

/* List-icon button */
.gh_button.icon.list-icon::before{
  background:none;width:14px;height:10px;display:block;flex-shrink:0;
  background-image:linear-gradient(var(--text-3),var(--text-3)),linear-gradient(var(--text-3),var(--text-3)),linear-gradient(var(--text-3),var(--text-3));
  background-size:14px 2px,14px 2px,14px 2px;
  background-position:0 0,0 4px,0 8px;
  background-repeat:no-repeat;
  transition:background-image var(--t);
}
.gh_button:hover.icon.list-icon::before,.gh_button:focus.icon.list-icon::before{
  background-image:linear-gradient(var(--accent-2),var(--accent-2)),linear-gradient(var(--accent-2),var(--accent-2)),linear-gradient(var(--accent-2),var(--accent-2));
}

/* Suppress old admin-only classes */
.ssw_trigger,.sw_width,.style_switcher,.sticky_nav,.bAct_hide,.bAct_toggle{display:none!important}



/* ==========================================================================
   Domain search box
   ========================================================================== */
.domain-search-wrap{
  padding:12px 20px;border-bottom:1px solid var(--border);
  background:var(--bg-2);
}
.domain-search-wrap input{
  width:100%;max-width:400px;
  background:var(--bg-3);
  border:1.5px solid var(--border-2);
  border-radius:var(--r);
  color:var(--text);
  padding:9px 14px 9px 36px;
  font-size:14px;font-family:var(--font);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='7' cy='7' r='5'/%3E%3Cline x1='11' y1='11' x2='14' y2='14'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:10px center;
  transition:border-color var(--t),box-shadow var(--t);
}
.domain-search-wrap input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(45,138,45,.15);
  outline:none;
}
.domain-search-wrap input::placeholder{color:var(--text-3)}
.domain-search-none{
  padding:20px;text-align:center;
  color:var(--text-3);font-size:14px;display:none;
}
@media only screen and (max-width:767px){
  .domain-search-wrap{padding:10px 14px}
  .domain-search-wrap input{max-width:100%}
}


#domainSearch{background:#f1f5f9;border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 14px 8px 36px;font-size:14px;font-family:inherit;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='7' cy='7' r='5'/%3E%3Cline x1='11' y1='11' x2='14' y2='14'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:10px center;outline:none;transition:border-color .18s;width:100%;box-sizing:border-box}
#domainSearch:focus{border-color:#2d8a2d;box-shadow:0 0 0 3px rgba(45,138,45,.15)}
#searchNone{padding:14px 20px;color:#94a3b8;font-size:14px;display:none}

#dt2 tbody tr.dom-hidden{display:none!important;visibility:hidden!important;height:0!important;overflow:hidden!important;padding:0!important;margin:0!important}
#dt2 tbody tr.dom-hidden td{display:none!important}

/* ==========================================================================
   Domain status badges
   ========================================================================== */
.dom-status{
  display:inline-block;padding:3px 10px;border-radius:50em;
  font-size:12px;font-weight:700;letter-spacing:.3px;
  font-family:var(--display);
}
.dom-status.aktiven{background:#dcfce7;color:#166534}
.dom-status.istecen{background:#fef3c7;color:#92400e}
.dom-status.izbrisan{background:#fee2e2;color:#991b1b}
.dom-status.unknown{background:var(--bg-3);color:var(--text-3)}

/* ==========================================================================
   RESPONSIVE — Tablet
   ========================================================================== */
@media only screen and (max-width:959px){
  .container{padding:0 16px}
  .container.head_s_a{padding:0 16px}
}
@media only screen and (min-width:768px) and (max-width:959px){
  .admin-contact,.tech-contact{width:100%;padding-right:0}
}

/* ==========================================================================
   RESPONSIVE — Mobile <=767px
   ========================================================================== */
@media only screen and (max-width:767px){

  /* Header: sticky, full width, explicit height so hamburger is fully inside */
  header{position:sticky;top:0;z-index:200;min-height:60px;width:100vw!important;max-width:100vw!important;left:0;box-sizing:border-box!important;overflow:hidden!important}
  .container.head_s_a{position:relative;padding-right:64px!important;padding-top:0!important;padding-bottom:0!important;min-height:60px;width:100%!important;max-width:100%!important;box-sizing:border-box!important;display:flex;align-items:center}
  .container.head_s_a .row{width:100%!important;max-width:100%!important;box-sizing:border-box!important;gap:8px}
  .container.head_s_a .twelve.columns{flex:1 1 auto!important;width:auto!important;max-width:100%!important;box-sizing:border-box!important;margin-bottom:0!important}
  #logo{padding:10px 0}
  #logo::after{display:none}

  /* Show hamburger */
  .nav-toggle{display:block!important}

  /* Nav: fixed below header, covers page content */
  #smoothmenu_h{
    display:none;
    position:fixed;
    top:60px;
    left:0;right:0;width:100%;
    background:var(--navy)!important;
    border-top:1px solid rgba(255,255,255,.1)!important;
    border-bottom:3px solid var(--accent)!important;
    box-shadow:0 8px 32px rgba(0,0,0,.4);
    z-index:199;
    max-height:calc(100vh - 60px);
    overflow-y:auto;
  }

  /* Checkbox checked — show nav */
  .nav-toggle-cb:checked~.container.head_s_a #smoothmenu_h{display:block!important}
  #smoothmenu_h ul{flex-direction:column!important;gap:0!important;padding:8px 0!important}
  #smoothmenu_h ul li{width:100%;display:block!important;float:none!important}
  #smoothmenu_h ul li:last-child{margin-left:0!important}
  #smoothmenu_h ul li>a{
    padding:14px 20px!important;font-size:16px!important;
    border-bottom:1px solid rgba(255,255,255,.08)!important;
    border-left:none!important;border-right:none!important;
    width:100%;display:block!important;border-bottom-width:1px!important;
  }
  #smoothmenu_h ul li>a:hover{border-bottom-color:rgba(255,255,255,.08)!important}
  #smoothmenu_h ul li:last-child>a{border-bottom:none!important}

  .container{padding:0 16px}
  .container>.row{padding-top:20px;padding-bottom:20px}

  /* Login */
  body:has(.login_form) .container,
  body.auth-screen .container{max-width:100%;padding:0}
  body:has(.login_form) .box_c,
  body.auth-screen .box_c{border-radius:0;box-shadow:none}
  body:has(.login_form) > .container:not(#footer)::before,
  body.auth-screen > .container:not(#footer)::before{margin-top:32px;margin-bottom:16px}

  body:has(.login_form) .box_c_heading,
  body.auth-screen .box_c_heading{border-radius:0}
  body:has(.login_form) .box_c_content,
  body.auth-screen .box_c_content{padding:20px}

  .six.columns,.four.columns,.three.columns,.two.columns,.eight.columns,.columns,.column{
    width:100%!important;float:none!important;padding:0!important;margin-bottom:16px
  }
  .twelve.columns{margin-bottom:0}
  .formRow{padding:14px 16px}
  .box_c_content{padding:16px}
  .box_c_heading{padding:0 16px}

  .admin-contact,.tech-contact,.nameservers{width:100%!important;float:none!important;padding-right:0!important}
  .ns-left,.ns-right{width:100%!important;float:none!important;padding-right:0!important}

  .sepH_c{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table.display{min-width:0}
  table.display tbody td.center{display:flex!important;flex-wrap:wrap;gap:4px;justify-content:center}

  input[type=submit],input[type=button]{max-width:100%!important;box-sizing:border-box!important}
}


@media only screen and (max-width:767px){
  /* Domain table — vertical card layout on mobile */
  table.display thead{display:none}
  table.display,table.display tbody,table.display td{
    display:block!important;width:100%!important;
  }
  table.display tbody tr{
    display:block!important;
    border:1px solid var(--border)!important;
    border-radius:var(--r)!important;
    margin-bottom:10px!important;
    padding:12px 14px!important;
    background:var(--bg-2)!important;
    box-shadow:0 1px 4px rgba(0,0,0,.05)!important;
  }
  table.display tbody tr[style*="display: none"],
  table.display tbody tr[style*="display:none"]{
    display:none!important;
  }
  table.display tbody tr:hover{background:var(--bg-3)!important}
  table.display tbody td{
    padding:4px 0!important;border:none!important;
    text-align:left!important;font-size:14px;
    display:flex!important;align-items:center;gap:8px;
  }
  table.display tbody td:first-child{display:none!important}
  table.display tbody td:nth-child(2){
    font-size:16px!important;font-weight:700!important;
    color:var(--navy)!important;padding-bottom:8px!important;
    border-bottom:1px solid var(--border)!important;margin-bottom:4px!important;
  }
  table.display tbody td:last-child{
    display:flex!important;flex-wrap:wrap!important;
    gap:6px!important;padding-top:10px!important;
    border-top:1px solid var(--border)!important;margin-top:4px!important;
    justify-content:flex-start!important;
  }
  table.display tbody td .gh_button{font-size:12px!important;padding:5px 10px!important}
  td.dom-contact,td.dom-ns,td.dom-info{display:block!important;padding:2px 0!important;font-size:14px;text-align:left!important}
  #dt2 tbody td{display:block!important;width:100%!important;padding:2px 0!important;text-align:left!important;border:none!important;font-size:14px}
  #dt2 tbody td:first-child{display:none!important}
  #dt2 tbody td:nth-child(2){font-size:16px!important;font-weight:700!important;color:var(--navy)!important;padding-bottom:8px!important;border-bottom:1px solid var(--border)!important;margin-bottom:6px!important}
  #dt2 tbody td:last-child{display:flex!important;flex-wrap:wrap;gap:6px;padding-top:10px!important;border-top:1px solid var(--border)!important;margin-top:6px!important}
  .box_c_heading{flex-wrap:nowrap}
  #domainSearch:focus{border-color:#2d8a2d;box-shadow:0 0 0 3px rgba(45,138,45,.15)}
}

@media only screen and (max-width:479px){
  body{font-size:15px}
  .gh_button{font-size:13px;padding:6px 12px}
}

/* ==========================================================================
   Domain table — global
   ========================================================================== */
#dt2 tbody tr.dom-hidden{display:none!important}
#dt2 tbody tr.dom-hidden td{display:none!important}

/* ==========================================================================
   Domain table — MOBILE cards
   ========================================================================== */
@media only screen and (max-width:767px){
  #dt2 thead{display:none!important}
  #dt2,#dt2 tbody{display:block!important}
  #dt2 tbody tr{
    display:block!important;background:var(--bg-2)!important;
    border:1px solid var(--border)!important;border-radius:var(--r)!important;
    margin-bottom:10px!important;padding:14px!important;
    box-shadow:0 1px 4px rgba(0,0,0,.05)!important;
  }
  #dt2 tbody td{display:block!important;padding:3px 0!important;border:none!important;font-size:14px!important;text-align:left!important;width:auto!important}
  #dt2 tbody td:first-child{display:none!important}
  #dt2 tbody td.dom-name{font-size:16px!important;font-weight:700!important;color:var(--navy)!important;padding-bottom:8px!important;border-bottom:1px solid var(--border)!important;margin-bottom:6px!important}
  #dt2 tbody td.dom-contact::before{content:'Контакт: ';font-weight:700;color:#94a3b8;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
  #dt2 tbody td.dom-ns::before{content:'NS: ';font-weight:700;color:#94a3b8;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
  #dt2 tbody td.dom-valen::before{content:'Валиден до: ';font-weight:700;color:#94a3b8;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
  #dt2 tbody td.dom-badge::before{content:'Статус: ';font-weight:700;color:#94a3b8;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
  #dt2 tbody td.dom-actions{display:flex!important;flex-wrap:wrap!important;gap:6px!important;padding-top:10px!important;border-top:1px solid var(--border)!important;margin-top:6px!important}
}

/* ==========================================================================
   Domain table — DESKTOP (must be last to win)
   ========================================================================== */
@media only screen and (min-width:768px){
  #dt2{display:table!important;width:100%!important;border-collapse:collapse!important}
  #dt2 thead{display:table-header-group!important}
  #dt2 thead tr{display:table-row!important;border-bottom:2px solid var(--border)!important}
  #dt2 thead th{display:table-cell!important;padding:12px 14px!important;font-size:12px!important;font-weight:600!important;text-transform:uppercase!important;letter-spacing:.8px!important;color:var(--text-3)!important;white-space:nowrap!important;text-align:left!important}
  #dt2 thead th:first-child{display:none!important}
  #dt2 tbody{display:table-row-group!important}
  #dt2 tbody tr{display:table-row!important;border-bottom:1px solid var(--border)!important;background:transparent!important;border-radius:0!important;box-shadow:none!important;margin:0!important;padding:0!important}
  #dt2 tbody tr.dom-hidden{display:none!important}
  #dt2 tbody tr[style*="display: none"]{display:none!important}
  #dt2 tbody tr[style*="display:none"]{display:none!important}
  #dt2 tbody tr:hover{background:var(--bg-3)!important}
  #dt2 tbody td{display:table-cell!important;padding:13px 14px!important;border:none!important;font-size:14px!important;vertical-align:middle!important;text-align:left!important;width:auto!important}
  #dt2 tbody td:first-child{display:none!important}
  #dt2 tbody td.dom-name{font-size:15px!important;font-weight:600!important;color:var(--navy)!important;width:25%!important}
  #dt2 tbody td.dom-contact,#dt2 tbody td.dom-ns{width:16%!important;white-space:nowrap!important}
  #dt2 tbody td.dom-valen{width:14%!important;white-space:nowrap!important}
  #dt2 tbody td.dom-badge{width:10%!important}
  #dt2 tbody td.dom-actions{width:1%!important;white-space:nowrap!important;text-align:left!important;display:table-cell!important;vertical-align:middle!important}
  #dt2 tbody td.dom-actions a{display:inline-flex!important;margin:0 4px 0 0!important}

  /* Sortable header */
  .th-sortable{cursor:pointer!important}
  .th-sortable:hover{color:var(--accent)!important}
  .sort-arrow{opacity:.5;font-size:11px;margin-left:4px}
  .th-sortable:hover .sort-arrow{opacity:1}
}

/* ── Language switcher ────────────────────────────────────────────── */
.lang-wrap { position:relative; margin-left:auto; padding:0 12px 0 0; flex-shrink:0; display:flex; align-items:center; }
.lang-select {
    appearance:none; -webkit-appearance:none;
    background:rgba(255,255,255,.1);
    border:1px solid rgba(255,255,255,.25);
    color:#fff; font-size:13px; font-weight:700;
    padding:5px 28px 5px 10px; border-radius:6px;
    cursor:pointer; outline:none; letter-spacing:.5px;
    transition:background .15s, border-color .15s;
    font-family:var(--display);
}
.lang-select:hover { background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.45); }
.lang-select option { background:#1a3d1a; color:#fff; font-weight:600; }
.lang-wrap::after {
    content:'▾'; position:absolute; right:22px;
    color:rgba(255,255,255,.7); font-size:11px; pointer-events:none;
}
@media(max-width:767px){ .lang-wrap { padding:0 8px; } .lang-select { font-size:12px; padding:4px 24px 4px 8px; } .lang-wrap::after { right:14px; } }

/* ── 2FA verification ───────────────────────────────────────────────────── */
.totp-error{
  padding:12px 16px;
  background:#fee2e2;
  border:1px solid #fca5a5;
  border-radius:14px;
  color:#991b1b;
  font-weight:700;
  margin-bottom:18px;
}
body:has(.totp-form) > .container:not(#footer)::before{
  content:'ProHost';
}
body:has(.totp-form) .box_c_content{
  padding:30px 28px 28px!important;
}
.totp-panel{
  margin:0 0 24px;
  display:block;
  text-align:center;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
}
.totp-icon{
  width:64px;
  height:64px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 18px;
  border-radius:22px;
  background:linear-gradient(135deg,#0f5a2e,#073d2b);
  color:#fff;
  font-size:28px;
  box-shadow:0 16px 32px rgba(20,92,46,.24);
}
.totp-step{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin:0 0 10px;
  padding:5px 10px;
  border-radius:999px;
  background:#eef7ef;
  color:#1f6a36;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.totp-panel h2{
  margin:0 0 10px;
  font-size:24px;
  line-height:1.2;
  color:#0f3f21;
}
.totp-panel p{
  margin:0 0 6px;
  font-size:15px;
  color:var(--text-2);
}
.totp-panel small{
  color:var(--text-3);
  line-height:1.45;
}
.totp-form{
  max-width:300px;
  margin:0 auto;
}
.totp-code-input{
  width:100%;
  text-align:center;
  font-size:28px;
  letter-spacing:10px;
  font-family:ui-monospace,SFMono-Regular,Consolas,monospace;
  padding:14px 12px 14px 22px;
  border:2px solid #bdd7bf;
  border-radius:16px;
  margin-bottom:12px;
  background:#fbfdfb;
  box-sizing:border-box;
}
.totp-code-input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(20,92,46,.12);
  outline:none;
}
.totp-submit{
  width:100%;
  min-height:44px;
  border-radius:14px!important;
  font-size:14px!important;
}
.totp-back{
  text-align:center;
  margin:18px 0 0;
  font-size:13px;
  color:var(--text-3);
}
@media(max-width:640px){
  .totp-panel{
    text-align:center;
  }
}

/* ==========================================================================
   Frontend Dashboard
   ========================================================================== */
.dashboard-shell{display:grid;gap:24px}
.dashboard-hero{
  display:grid;grid-template-columns:1.3fr .9fr;gap:0;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.12), transparent 35%),
    linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 55%,#0c3460 100%);
  color:#fff;
}
.dashboard-hero-main{padding:34px 28px}
.dashboard-kicker{
  display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;
  background:rgba(255,255,255,.12);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;
}
.dashboard-hero-title{font-size:32px;font-weight:700;color:#fff;line-height:1.15;margin-bottom:10px}
.dashboard-hero-copy{font-size:15px;color:rgba(255,255,255,.78);max-width:640px}
.dashboard-hero-meta{margin-top:22px;display:flex;flex-wrap:wrap;gap:10px}
.dashboard-pill{
  display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:999px;background:rgba(255,255,255,.1);
  font-size:13px;font-weight:600;color:#fff;
}
.dashboard-pill strong{font-family:var(--display);font-size:16px;color:#fff}
.dashboard-hero-side{
  padding:28px;border-left:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);
  display:flex;flex-direction:column;justify-content:center;
}
.dashboard-side-title{font-family:var(--display);font-size:14px;font-weight:700;color:rgba(255,255,255,.74);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}
.dashboard-side-card{padding:18px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.dashboard-side-big{font-family:var(--display);font-size:34px;line-height:1;color:#fff;margin-bottom:8px}
.dashboard-side-label{font-size:14px;font-weight:700;color:#fff;margin-bottom:4px}
.dashboard-side-copy{font-size:13px;color:rgba(255,255,255,.76)}
.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.dashboard-stat{
  display:block;padding:24px 20px;text-align:center;border-right:1px solid var(--border);text-decoration:none;
  transition:background var(--t),transform var(--t);
}
.dashboard-stat:last-child{border-right:none}
.dashboard-stat:hover{background:var(--bg-3)}
.dashboard-stat-num{font-family:var(--display);font-size:48px;font-weight:700;line-height:1;margin-bottom:6px;color:var(--navy)}
.dashboard-stat-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3)}
.dashboard-stat.s-active{border-top:3px solid #22c55e}
.dashboard-stat.s-expiring{border-top:3px solid #3b82f6}
.dashboard-stat.s-expired{border-top:3px solid #f59e0b}
.dashboard-stat.s-deleted{border-top:3px solid #ef4444}
.dashboard-stat.s-active .dashboard-stat-num{color:#16a34a}
.dashboard-stat.s-expiring .dashboard-stat-num{color:#2563eb}
.dashboard-stat.s-expired .dashboard-stat-num{color:#d97706}
.dashboard-stat.s-deleted .dashboard-stat-num{color:#dc2626}
.dashboard-main-grid{display:grid;grid-template-columns:1fr;gap:24px}
.dashboard-card-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 20px;min-height:56px;border-bottom:1px solid var(--border);
}
.dashboard-card-head h2{font-size:18px}
.dashboard-card-head p{font-size:13px;color:var(--text-3)}
.dashboard-attention-list,.dashboard-timeline{display:grid;gap:0}
.dashboard-attention-item{
  display:flex;align-items:center;gap:14px;padding:14px 20px;border-top:1px solid var(--border);transition:background var(--t);
}
.dashboard-attention-item:first-child,.dashboard-timeline-item:first-child{border-top:none}
.dashboard-attention-item:hover{background:var(--bg-3)}
.dashboard-domain-main{flex:1;min-width:0}
.dashboard-domain-name{
  font-family:var(--display);font-size:18px;font-weight:700;color:var(--navy);margin-bottom:4px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.dashboard-domain-meta{font-size:13px;color:var(--text-2)}
.dashboard-domain-date{font-size:13px;color:var(--text-3);white-space:nowrap}
.dashboard-badge{
  display:inline-flex;align-items:center;justify-content:center;min-width:70px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap;
}
.dashboard-badge.urgent{background:#fee2e2;color:#991b1b}
.dashboard-badge.warning{background:#fef3c7;color:#92400e}
.dashboard-badge.ok{background:#e0f2fe;color:#0369a1}
.dashboard-empty{padding:26px 20px;text-align:center;color:var(--text-3);font-size:14px}
.dashboard-timeline-item{
  display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:flex-start;padding:14px 20px;border-top:1px solid var(--border);
}
.dashboard-timeline-badge{
  display:inline-flex;align-items:center;justify-content:center;min-width:56px;padding:6px 10px;border-radius:999px;
  background:#dcfce7;color:#166534;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
}
.dashboard-timeline-main{min-width:0}
.dashboard-timeline-title{font-family:var(--display);font-size:15px;font-weight:700;color:var(--navy);margin-bottom:4px}
.dashboard-timeline-copy{font-size:14px;color:var(--text-2);line-height:1.5}
.dashboard-timeline-date{font-size:12px;color:var(--text-3);white-space:nowrap}
.dashboard-landing-hero{
  background:linear-gradient(135deg,var(--navy) 0%,#1a5c1a 100%);padding:52px 40px 48px;text-align:center;position:relative;overflow:hidden;
}
.dashboard-landing-hero::before{
  content:'';position:absolute;inset:0;opacity:.07;background:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 50%);background-size:20px 20px;
}
.dashboard-landing-inner{position:relative;z-index:1}
.dashboard-landing-icon{font-size:48px;margin-bottom:12px}
.dashboard-landing-title{font-family:var(--display);font-size:28px;font-weight:700;color:#fff;margin:0 0 10px;line-height:1.2}
.dashboard-landing-copy{font-size:16px;color:rgba(255,255,255,.75);margin:0 auto 28px;max-width:500px}
.dashboard-landing-cta{font-size:16px;padding:12px 32px;border-radius:8px}
.dashboard-landing-grid{display:flex;flex-wrap:wrap;gap:0;border-top:1px solid var(--border)}
.dashboard-landing-feature{flex:1;min-width:200px;padding:28px 28px 24px;border-right:1px solid var(--border)}
.dashboard-landing-feature:last-child{border-right:none}
.dashboard-landing-feature-icon{font-size:28px;margin-bottom:10px}
.dashboard-landing-feature-title{font-family:var(--display);font-weight:700;font-size:15px;color:var(--navy);margin-bottom:6px}
.dashboard-landing-feature-copy{font-size:13px;color:var(--text-2);line-height:1.6}
.dashboard-landing-footer{
  padding:20px 28px;background:var(--bg-3);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.dashboard-landing-footer span{font-size:14px;color:var(--text-2)}
@media only screen and (max-width:767px){
  .dashboard-hero{grid-template-columns:1fr}
  .dashboard-hero-main,.dashboard-hero-side{padding:22px 18px}
  .dashboard-hero-side{border-left:none;border-top:1px solid rgba(255,255,255,.12)}
  .dashboard-hero-title{font-size:26px}
  .dashboard-stats{grid-template-columns:repeat(2,1fr)}
  .dashboard-stat{padding:16px 10px}
  .dashboard-stat-num{font-size:32px}
  .dashboard-main-grid{grid-template-columns:1fr}
  .dashboard-attention-item{align-items:flex-start;flex-wrap:wrap}
  .dashboard-domain-name{white-space:normal}
  .dashboard-timeline-item{grid-template-columns:1fr;gap:8px}
  .dashboard-timeline-date{white-space:normal}
  .dashboard-landing-hero{padding:38px 22px 34px}
  .dashboard-landing-title{font-size:24px}
  .dashboard-landing-grid{display:block}
  .dashboard-landing-feature{border-right:none;border-bottom:1px solid var(--border)}
  .dashboard-landing-feature:last-child{border-bottom:none}
  .dashboard-landing-footer{padding:18px 20px}
}

/* ==========================================================================
   Domain details / domain page
   ========================================================================== */
.domain-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg-2);
}
.domain-toolbar-copy{font-size:14px;color:var(--text-2)}
.domain-toolbar-actions{display:flex;flex-wrap:wrap;gap:8px}
.domain-toolbar-actions .gh_button{margin-left:0}
.domain-hero{
  display:grid;grid-template-columns:1.1fr .9fr;gap:0;
  background:
    radial-gradient(circle at 82% 16%,rgba(34,197,94,.18),transparent 26%),
    radial-gradient(circle at 12% 88%,rgba(14,165,233,.12),transparent 28%),
    linear-gradient(135deg,#0f4b16 0%,#14532d 48%,#12395a 100%);
  color:#fff;border-bottom:1px solid rgba(255,255,255,.08);
}
.domain-hero-main{padding:38px 32px}
.domain-hero-kicker{
  display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:rgba(220,252,231,.16);
  color:#dcfce7;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;
}
.domain-hero-title{font-family:var(--display);font-size:34px;font-weight:700;color:#fff;line-height:1.15;margin-bottom:10px;letter-spacing:0}
.domain-hero-copy{font-size:16px;color:rgba(255,255,255,.78);line-height:1.65;max-width:620px}
.domain-hero-side{
  padding:30px;border-left:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;
}
.domain-stat{
  padding:16px 17px;border-radius:16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
}
.domain-stat-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.68);margin-bottom:6px}
.domain-stat-value{font-family:var(--display);font-size:16px;font-weight:700;color:#fff;line-height:1.3;word-break:break-word}
  .domain-edit-shell{padding:24px}
  .domain-summary-grid,
  .domain-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
  .domain-summary-grid > *,
  .domain-edit-grid > *{min-width:0}
  .domain-panel{
    border:1px solid var(--border);border-radius:16px;background:#fff;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,.04);
  }
  .domain-panel-head{
    display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg-3);
}
  .domain-panel-head h3{font-size:16px}
  .domain-panel-head p{font-size:13px;color:var(--text-3)}
  .domain-panel-body{padding:18px 16px}
  .domain-form{display:block}
  .domain-form .row,
  .domain-form .columns{width:100%!important;float:none!important;margin:0!important;padding:0!important}
  .domain-fields{display:grid;gap:14px}
  .domain-field{display:grid;gap:7px}
  .domain-field label{
    display:block;margin:0;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);
  }
  .domain-field .input-text,
  .domain-field input[type=text],
  .domain-field input[type=email],
  .domain-field input[type=password]{
    width:100%!important;max-width:none!important;box-sizing:border-box!important;margin:0!important;
  }
  .domain-readonly-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
  .domain-readonly-row label{margin:0;white-space:nowrap}
  .domain-readonly-row .input-text{margin:0;max-width:none;flex:1 1 260px}
.domain-alert{
  display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border-radius:10px;margin-bottom:16px;border:1px solid transparent;
}
.domain-alert.success{background:#dcfce7;border-color:#86efac;color:#166534}
.domain-alert.error{background:#fee2e2;border-color:#fca5a5;color:#991b1b}
.domain-alert.info{background:#f1f5f9;border-color:#cbd5e1;color:#475569}
.domain-alert-icon{font-size:20px;line-height:1.4;flex-shrink:0}
.domain-alert-body{font-size:14px;line-height:1.7}
.domain-alert-body strong{display:block;font-size:15px;margin-bottom:2px}
.domain-alert-body div+div{margin-top:2px}
  .domain-note{
    background:#fef3c7;border:1px solid #fde68a;border-radius:var(--r);padding:16px 20px;color:#78350f;line-height:1.75;
  }
  .domain-note-wide{width:100%;display:block}
  .domain-note strong{display:block;font-size:15px;margin-bottom:8px}
  .domain-form-actions{clear:both;padding-top:18px;margin-top:4px}
  .domain-form-actions .button,
  .domain-form-actions .gh_button{margin-left:0}
  .domain-form-actions .button{min-width:145px}
  .domain-note-copy b{font-weight:700}
  .domain-editor{display:grid;gap:18px}
  .domain-editor-nav{
    display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:8px;border:1px solid var(--border);
    border-radius:16px;background:#f8fafc;
  }
  .domain-editor-tab{
    border:0;border-radius:12px;background:transparent;color:var(--text-2);font-family:var(--body);font-size:13px;font-weight:800;
    padding:12px 10px;cursor:pointer;text-align:center;transition:background .18s ease,color .18s ease,box-shadow .18s ease;
  }
  .domain-editor-tab:hover{background:#fff;color:var(--navy)}
  .domain-editor-tab.active{background:var(--navy);color:#fff;box-shadow:0 10px 24px rgba(15,23,42,.16)}
  .domain-editor-panel{display:none}
  .domain-editor-panel.active{display:block}
  .domain-task-layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:18px;align-items:start}
  .domain-task-card{
    border:1px solid var(--border);border-radius:18px;background:#fff;box-shadow:0 12px 30px rgba(15,23,42,.06);overflow:hidden;
  }
  .domain-task-head{
    padding:20px 22px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#f8fafc 0%,#ecfdf5 100%);
  }
  .domain-task-kicker{
    display:inline-flex;margin-bottom:8px;padding:5px 9px;border-radius:999px;background:#dcfce7;color:#166534;
    font-size:10px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;
  }
  .domain-task-head h3{font-family:var(--display);font-size:22px;color:var(--navy);margin:0 0 6px}
  .domain-task-head p{font-size:14px;line-height:1.6;color:var(--text-2);margin:0}
  .domain-task-form{padding:20px 22px}
  .domain-task-form .domain-fields{max-width:560px;gap:16px}
  .domain-task-form .domain-field{display:grid;gap:8px}
  .domain-task-form .domain-field label{
    color:#64748b;font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;
  }
  .domain-task-form .domain-field .input-text,
  .domain-task-form .domain-field input[type=text],
  .domain-task-form .domain-field input[type=email],
  .domain-task-form .domain-field input[type=tel]{
    width:100%!important;max-width:560px!important;height:44px!important;padding:0 14px!important;
    border:1.5px solid #cbd5e1!important;border-radius:9px!important;background:#fff!important;
    box-sizing:border-box!important;font-size:14px!important;color:#0f172a!important;
  }
  .domain-task-form .domain-field .input-text:focus,
  .domain-task-form .domain-field input[type=text]:focus,
  .domain-task-form .domain-field input[type=email]:focus,
  .domain-task-form .domain-field input[type=tel]:focus{
    border-color:var(--accent)!important;box-shadow:0 0 0 3px rgba(22,101,52,.1)!important;outline:none!important;
  }
  .domain-guidance-card{
    border:1px solid #bbf7d0;border-radius:18px;background:#f0fdf4;color:#14532d;padding:18px;line-height:1.65;
  }
  .domain-guidance-card.warning{border-color:#fde68a;background:#fffbeb;color:#78350f}
  .domain-guidance-card strong{display:block;font-size:14px;margin-bottom:6px;color:inherit}
  .domain-guidance-card p{margin:0;font-size:13px;line-height:1.7;color:inherit}
  .section-change-preview{
    display:none;margin-top:16px;border:1px solid #bbf7d0;border-radius:14px;background:#f0fdf4;padding:12px;
  }
  .domain-task-form.has-unsaved .section-change-preview{display:grid;gap:8px}
  .section-change-item{
    display:grid;grid-template-columns:150px minmax(0,1fr) minmax(0,1fr);gap:8px;align-items:center;padding:8px;border-radius:10px;background:#fff;
  }
  .section-change-name{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:#64748b}
  .section-change-old,.section-change-new{font-size:13px;line-height:1.35;word-break:break-word}
  .section-change-old{color:#64748b}
  .section-change-new{color:#166534;font-weight:800}
  .domain-form-actions-smart{
    display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--border);padding-top:16px;margin-top:18px;
  }
  .save-state{font-size:13px;font-weight:800;color:#64748b}
  .domain-task-form.has-unsaved .save-state{color:#166534}
  .domain-form-actions-smart input[type=submit]:disabled{
    opacity:1;cursor:not-allowed;filter:none;background:#a7b0a6!important;color:#fff!important;border-color:#a7b0a6!important;
    box-shadow:none!important;
  }
  .domain-timeline-panel-embedded{margin-top:0}
  .action-confirm-shell{padding:24px}
  .action-confirm-card{
    display:flex;align-items:flex-start;gap:20px;padding:22px;background:var(--bg-3);
    border:1px solid var(--border);border-radius:16px;margin-bottom:24px;
  }
  .action-confirm-icon{
    width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;
    background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
  }
  .action-confirm-icon svg{width:20px;height:20px;display:block}
  .action-confirm-kicker{
    font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:4px;
  }
  .action-confirm-title{
    font-family:var(--display);font-size:24px;font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:8px;
  }
  .action-confirm-copy{font-size:14px;color:var(--text-2);line-height:1.7}
  .action-confirm-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
  .epp-confirm-card{
    background:linear-gradient(135deg,#fff8e6 0%,#f8fafc 62%,#ecfdf5 100%);
    border-color:#f7d37b;
    box-shadow:0 16px 38px rgba(120,53,15,.08);
  }
  .epp-confirm-icon{background:linear-gradient(135deg,#d97706,#0f5b22)}
  .epp-destination-grid{
    display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:16px;
  }
  .epp-destination-card{
    padding:16px 18px;border:1px solid var(--border);border-radius:14px;background:#fff;
    box-shadow:0 10px 22px rgba(15,23,42,.04);
  }
  .epp-destination-card span{
    display:block;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:6px;
  }
  .epp-destination-card strong{
    display:block;color:var(--navy);font-family:var(--display);font-size:18px;line-height:1.25;overflow-wrap:anywhere;
  }
  .epp-sensitive-note{
    padding:16px 18px;border-radius:14px;background:#fff7ed;border:1px solid #fed7aa;color:#7c2d12;
    font-size:14px;line-height:1.7;margin-bottom:20px;
  }
  .epp-sensitive-note strong{display:block;margin-bottom:5px;color:#7c2d12}
  .epp-confirm-form{margin:0}
  .epp-confirm-check{
    display:flex;align-items:flex-start;gap:10px;max-width:680px;margin:0 auto 18px;padding:13px 15px;
    border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text-2);font-size:14px;line-height:1.5;
  }
  .epp-confirm-check input{width:18px;height:18px;margin-top:1px;accent-color:var(--accent)}
  .epp-confirm-actions{justify-content:center;margin-top:18px}
  .epp-confirm-actions input[type=submit]{min-width:190px}
  .epp-cancel-link{color:var(--text-3);font-size:14px;text-decoration:none}
  .epp-cancel-link:hover{color:var(--navy);text-decoration:underline}
  .epp-result-success .action-result-emoji{
    width:58px;height:58px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
    background:#dcfce7;color:#166534;font-size:34px;font-weight:800;
  }
  .epp-success-hint{
    max-width:560px;margin:0 auto 22px;padding:13px 16px;border-radius:12px;background:#f0fdf4;border:1px solid #bbf7d0;
    color:#166534;font-size:14px;line-height:1.6;
  }
  .action-result{
    text-align:center;padding:40px 20px;
  }
  .action-result-emoji{font-size:46px;margin-bottom:16px}
  .action-result-title{font-family:var(--display);font-size:24px;font-weight:700;line-height:1.2;margin-bottom:8px}
  .action-result-copy{font-size:14px;color:var(--text-3);margin-bottom:24px;line-height:1.7}
  .action-error{
    padding:16px 20px;background:#fee2e2;border:1px solid #fca5a5;border-radius:10px;color:#991b1b;margin-bottom:20px;
  }
  .action-error p{margin:4px 0}
  .timeline-shell{padding:24px}
  .audit-shell{padding:0;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)}
  .audit-toolbar{
    display:grid;grid-template-columns:minmax(260px,1fr) minmax(220px,320px);gap:16px;align-items:end;
    padding:20px;border-bottom:1px solid var(--border);background:#fff;
  }
  .audit-search{position:relative}
  .audit-search span{
    position:absolute;left:14px;top:50%;width:14px;height:14px;transform:translateY(-50%);
    border:2px solid #94a3b8;border-radius:50%;pointer-events:none;
  }
  .audit-search span::after{
    content:'';position:absolute;width:7px;height:2px;background:#94a3b8;right:-6px;bottom:-3px;transform:rotate(45deg);border-radius:999px;
  }
  .audit-search input{
    width:100%;box-sizing:border-box;border:1.5px solid var(--border-2);border-radius:14px;background:#f8fafc;
    padding:12px 14px 12px 40px;font-size:15px;font-family:inherit;color:var(--text);outline:none;transition:border-color var(--t),box-shadow var(--t),background var(--t);
  }
  .audit-search input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px rgba(45,138,45,.12)}
  .audit-filter-select{
    display:grid;
    gap:7px;
    margin:0;
  }
  .audit-filter-select label{
    color:#64748b;
    font-family:var(--display);
    font-size:11px;
    font-weight:900;
    letter-spacing:.08em;
    text-transform:uppercase;
  }
  .audit-filter-select select{
    width:100%;
    height:46px;
    box-sizing:border-box;
    border:1.5px solid var(--border-2);
    border-radius:14px;
    background:#f8fafc;
    color:var(--navy);
    padding:0 14px;
    font-family:var(--display);
    font-size:14px;
    font-weight:800;
    line-height:46px;
  }
  .audit-filter-select select:focus{
    border-color:var(--accent);
    background:#fff;
    box-shadow:0 0 0 4px rgba(45,138,45,.12);
  }
  .audit-list{padding:12px 20px 4px;display:grid;gap:10px}
  .audit-no-results{
    display:none;margin:8px 0 14px;padding:22px;border:1px dashed var(--border-2);border-radius:16px;
    background:#fff;color:var(--text-3);text-align:center;font-weight:700;
  }
  .log-row{
    display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:flex-start;gap:14px;
    padding:16px;border:1px solid var(--border);border-radius:16px;background:#fff;
    box-shadow:0 12px 28px rgba(15,23,42,.04);transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  }
  .log-row:hover{transform:translateY(-1px);box-shadow:0 16px 34px rgba(15,23,42,.08);border-color:#cbd5e1}
  .log-icon{
    width:38px;height:38px;border-radius:14px;display:flex;align-items:center;justify-content:center;
    flex-shrink:0;font-size:17px;font-weight:900;font-family:var(--display);letter-spacing:.02em;
  }
  .log-icon.login{background:#dcfce7;color:#166534}
  .log-icon.logout{background:#f1f5f9;color:#475569}
  .log-icon.security{background:#fee2e2;color:#991b1b}
  .log-icon.password{background:#fef3c7;color:#92400e}
  .log-icon.domain{background:#dbeafe;color:#1d4ed8}
  .log-icon.contact{background:#ede9fe;color:#5b21b6}
  .log-icon.default{background:var(--bg-3);color:var(--text-3)}
  .log-text{min-width:0;font-size:14px;color:var(--text);line-height:1.55}
  .log-message{font-weight:650;color:var(--navy);overflow-wrap:anywhere}
  .log-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px}
  .log-meta{display:inline-flex;padding:4px 8px;border-radius:999px;background:#f8fafc;color:var(--text-3);font-size:11px;font-weight:700}
  .log-kind{background:#ecfdf5;color:#166534}
  .log-date{font-size:12px;color:var(--text-3);white-space:nowrap;margin-top:2px;flex-shrink:0}
  .timeline-empty{
    text-align:center;padding:40px 20px;color:var(--text-3);
  }
  .timeline-empty-emoji{font-size:34px;margin-bottom:10px}
  .timeline-summary{
    display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
    padding:16px 20px;border-top:1px solid var(--border);font-size:13px;color:var(--text-3);background:#fff;
  }
  .timeline-summary form{display:flex;align-items:center;gap:6px;margin:0;flex-wrap:wrap}
  .timeline-pagination{
    display:flex;align-items:center;justify-content:center;gap:4px;padding:16px 20px;flex-wrap:wrap;border-top:1px solid var(--border);background:#fff;
  }
  .timeline-pagination a,
  .timeline-pagination span.page-current{
    display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 10px;border-radius:6px;font-size:13px;text-decoration:none;
    border:1.5px solid var(--border-2);background:#fff;color:inherit;
  }
  .timeline-pagination span.page-current{
    border-color:var(--accent);background:var(--accent);color:#fff;font-weight:700;
  }
  .timeline-ellipsis{padding:0 4px;color:var(--text-3)}
  .profile-shell{padding:24px}
  .profile-icon{
    width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,#e8f5ee,#eaf2ff);color:#1d6fd8;flex-shrink:0;
    box-shadow:inset 0 0 0 1px rgba(34,197,94,.12);
  }
  .profile-icon svg{width:17px;height:17px;display:block;stroke-width:2}
  .profile-banner{
    margin:0;padding:12px 20px;border-bottom:1px solid;font-size:14px;font-weight:600;
  }
  .profile-banner.success{background:#dcfce7;border-bottom-color:#86efac;color:#166534}
  .profile-banner.error{background:#fee2e2;border-bottom-color:#fca5a5;color:#991b1b}
  .profile-tabs{
    display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:0;padding:0 24px;background:#fff;
  }
  .profile-tab{
    padding:14px 20px;font-size:14px;font-weight:600;color:var(--text-3);cursor:pointer;text-decoration:none;
    border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;
  }
  .profile-tab.active,.profile-tab:hover{color:var(--accent-2);border-bottom-color:var(--accent)}
  .profile-tab.active{color:var(--navy);border-bottom-color:var(--navy)}
  .profile-pane{display:none}
  .profile-pane.active{display:block}
  .profile-pane-inner{padding:28px 24px}
  .profile-lead{font-size:14px;color:var(--text-2);margin-bottom:20px;line-height:1.7}
  .profile-card{
    border:1px solid var(--border);border-radius:16px;background:#fff;box-shadow:0 1px 6px rgba(0,0,0,.04);overflow:hidden;
  }
  .profile-card + .profile-card{margin-top:20px}
  .profile-card-head{
    padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg-3);
  }
  .profile-card-head h3{font-size:16px}
  .profile-card-head p{font-size:13px;color:var(--text-3)}
  .profile-card-body{padding:18px 16px}
  .profile-form{max-width:460px}
  .profile-form-row{margin-bottom:14px}
  .profile-form-row:last-child{margin-bottom:0}
  .profile-form-row label{display:block;margin-bottom:4px;font-size:14px}
  .profile-input-note{margin-bottom:16px;font-size:12px;line-height:1.9}
  .profile-status{
    display:flex;align-items:center;gap:12px;padding:16px 20px;border:1px solid var(--border);border-radius:var(--r);margin-bottom:24px;
  }
  .profile-status.success{background:#dcfce7;border-color:#86efac}
  .profile-status.neutral{background:#f1f5f9}
  .profile-status-icon{font-size:24px}
  .profile-status-copy strong{display:block;font-size:15px}
  .profile-status.success .profile-status-copy strong,
  .profile-status.success .profile-status-copy div{color:#166534}
  .profile-status.neutral .profile-status-copy strong{color:var(--navy)}
  .profile-status.neutral .profile-status-copy div{color:var(--text-2)}
  .profile-inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
  .profile-inline-form .input-text.narrow{
    width:140px!important;letter-spacing:4px;font-size:18px;text-align:center;
  }
  .profile-step-row{display:flex;align-items:flex-start;gap:0;margin-bottom:14px;font-size:14px;color:var(--text-2)}
  .profile-step-num{
    display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;
    background:var(--navy);color:#fff;font-size:12px;font-weight:700;margin-right:8px;flex-shrink:0;
  }
.profile-qr{display:block;margin:16px 0;border-radius:var(--r);border:1px solid var(--border)}
.profile-qr-code{width:200px;height:200px;margin:0 auto}
  .profile-secret{
    font-family:monospace;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);
    padding:10px 14px;font-size:15px;letter-spacing:2px;word-break:break-all;margin-bottom:16px;
  }
  .client-profile-card{border:1px solid var(--border);border-radius:18px;background:#fff;overflow:hidden;box-shadow:0 1px 10px rgba(15,32,64,.05)}
  .client-profile-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:20px 22px;background:linear-gradient(135deg,#f8fafc,#eef7ee);border-bottom:1px solid var(--border)}
  .client-profile-head h3{font-family:var(--display);font-size:21px;color:var(--navy);margin-bottom:4px}
  .client-profile-head p{font-size:14px;color:var(--text-2);line-height:1.55}
  .client-info-section{padding:20px 22px;border-bottom:1px solid var(--border)}
  .client-info-section:last-child{border-bottom:none}
  .client-section-title{font-family:var(--display);font-size:13px;font-weight:800;color:var(--accent-2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
  .client-details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 22px}
  .client-field-list{display:grid;gap:14px}
  .client-field{display:grid;gap:7px}
  .client-field-wide{grid-column:1/-1}
  .client-field label{
    display:block;margin:0;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);
  }
  .client-field .input-text{
    width:100%!important;max-width:none!important;box-sizing:border-box!important;margin:0!important;
  }
  .client-pill{
    display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.15);font-size:12px;font-weight:700;letter-spacing:.04em;
  }
  .client-compact-note{margin-top:18px}
.domain-table-topline{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding:16px 20px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
}
.domain-table-title{font-family:var(--display);font-size:18px;font-weight:800;color:var(--navy);line-height:1.2}
.domain-table-copy{font-size:14px;color:var(--text-2)}
.domain-filter-banner{
  padding:12px 20px;border-bottom:2px solid;display:flex;align-items:center;gap:10px;font-size:14px;
}
.domain-filter-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.domain-filter-dismiss{
  opacity:.6;font-size:13px;text-decoration:none;margin-left:auto;border:1px solid;padding:3px 10px;border-radius:20px;
}
.domain-search-bar{padding:14px 20px;border-bottom:1px solid #e2e8f0;background:#fff}
.domain-search-bar #domainSearch{
  display:block;width:100%;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:14px;
  padding:12px 14px 12px 40px;font-size:15px;font-family:inherit;
}
.domain-search-bar #domainSearch:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(45,138,45,.12);background:#fff}
.domain-search-none{
  display:none;padding:16px 20px;border-bottom:1px solid var(--border);background:#fff;color:var(--text-3);font-size:14px;font-weight:700;
}
.domain-table-footer{
  display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid #e2e8f0;font-size:13px;color:var(--text-3);gap:12px;flex-wrap:wrap;
}
.domain-per-page{display:flex;align-items:center;gap:8px;margin:0}
.domain-per-page select{
  border:1.5px solid var(--border-2);border-radius:6px;padding:4px 8px;font-size:13px;font-family:inherit;background:#fff;cursor:pointer;width:auto;
}
.domain-pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px;flex-wrap:wrap}
@media only screen and (max-width:767px){
  .domain-toolbar{padding:12px 16px}
  .domain-hero{grid-template-columns:1fr}
  .domain-hero-main{padding:24px 20px}
  .domain-hero-title{font-size:28px}
  .domain-hero-side{padding:24px 20px;border-left:none;border-top:1px solid rgba(255,255,255,.12)}
  .domain-edit-shell{padding:16px}
  .domain-summary-grid,
  .domain-edit-grid,
  .client-details-grid{grid-template-columns:1fr}
  .client-profile-head{display:block}
  .client-profile-head .client-pill{margin-top:12px}
  .domain-readonly-row .input-text{max-width:100%}
  .domain-editor-nav{grid-template-columns:1fr}
  .domain-task-layout{grid-template-columns:1fr}
  .domain-task-head,.domain-task-form{padding:18px}
  .domain-task-form .domain-fields,
  .domain-task-form .domain-field .input-text,
  .domain-task-form .domain-field input[type=text],
  .domain-task-form .domain-field input[type=email],
  .domain-task-form .domain-field input[type=tel]{max-width:100%!important}
  .section-change-item{grid-template-columns:1fr}
  .domain-form-actions-smart{align-items:stretch;flex-direction:column}
  .domain-form-actions-smart input[type=submit]{width:100%}
  .domain-table-topline,.domain-table-footer{padding:12px 16px}
  .action-confirm-shell{padding:16px}
  .action-confirm-card{padding:18px;flex-direction:column}
  .action-confirm-title{font-size:21px}
  .epp-destination-grid{grid-template-columns:1fr}
  .epp-confirm-actions{align-items:stretch}
  .epp-confirm-actions input[type=submit],
  .epp-confirm-actions .gh_button,
  .epp-confirm-actions .epp-cancel-link{width:100%;text-align:center;justify-content:center}
  .timeline-shell{padding:16px}
  .audit-toolbar{grid-template-columns:1fr;padding:16px}
  .audit-list{padding:12px 16px 4px}
  .log-row{grid-template-columns:auto minmax(0,1fr);gap:12px;padding:14px}
  .log-side{grid-column:2;justify-items:start}
  .log-date{white-space:normal;margin-top:-4px}
  .profile-shell{padding:16px}
  .profile-tabs{padding:0 16px;overflow:auto}
  .profile-tab{padding:12px 14px;font-size:13px;white-space:nowrap}
  .profile-pane-inner{padding:20px 16px}
  }

/* ==========================================================================
   v=8 Polish layer — additive-only refinements
   Shared alert/notice components (replace inline style blocks), consistent
   focus rings for accessibility, subtle typography + form field polish.
   Safe to append: scoped to new classes or :focus-visible so existing
   inline styles continue to work unchanged.
   ========================================================================== */

/* --- Alert / notice components -------------------------------------------- */
.alert{
  margin-bottom:16px;padding:14px 18px;
  border:1.5px solid transparent;border-radius:var(--r);
  font-weight:600;line-height:1.4;
  display:flex;align-items:flex-start;gap:10px;
}
.alert::before{flex:0 0 auto;font-weight:700;font-size:15px;line-height:1.4}
.alert-error{background:#fee2e2;border-color:#fca5a5;color:#991b1b}
.alert-error::before{content:'✕'}
.alert-success{background:#dcfce7;border-color:#86efac;color:#166534}
.alert-success::before{content:'✓'}
.alert-info{background:#e0f2fe;border-color:#7dd3fc;color:#075985}
.alert-info::before{content:'ℹ'}
.alert-warning{background:#fef3c7;border-color:#fcd34d;color:#92400e}
.alert-warning::before{content:'⚠'}

/* --- Operational icon buttons -------------------------------------------- */
.gh_button.ui-icon::before{
  content:'';
  width:17px;height:17px;border-radius:5px;
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;color:currentColor;border:1px solid rgba(15,61,15,.16);
  font-family:var(--display);font-size:11px;font-weight:900;line-height:1;
  filter:none!important;
}
.gh_button.ui-icon.small{padding:6px 12px;font-size:13px}
.gh_button.ui-icon.action-details::before{content:'\270E'}
.gh_button.ui-icon.action-epp::before{content:'@'}
.gh_button.ui-icon.action-log::before{content:'#'}
.gh_button.ui-icon.action-profile::before{content:'P'}
.gh_button.ui-icon.action-copy::before{content:'C'}
.gh_button.ui-icon:hover::before{border-color:rgba(45,138,45,.35);background:#ecfdf5}

/* --- Domain list usefulness ---------------------------------------------- */
.dom-name-wrap{display:flex;align-items:center;gap:8px;min-width:0}
.dom-name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.copy-domain-btn{
  width:28px;height:28px;border:1px solid var(--border);border-radius:7px;background:#fff;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t);
}
.copy-domain-btn::before{
  content:'';width:12px;height:14px;border:2px solid var(--text-3);border-radius:3px;box-sizing:border-box;
  box-shadow:4px -4px 0 -2px #fff,4px -4px 0 0 var(--text-3);
}
.copy-domain-btn:hover{border-color:var(--accent);background:#ecfdf5}
.copy-domain-btn:hover::before{border-color:var(--accent-2);box-shadow:4px -4px 0 -2px #ecfdf5,4px -4px 0 0 var(--accent-2)}
.copy-domain-btn.copied{background:#dcfce7;border-color:#86efac}
.copy-domain-btn.copied::before{content:'✓';border:none;box-shadow:none;color:#166534;font-weight:900;font-family:var(--display)}
.domain-title-with-copy{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.copy-domain-btn-light{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.24)}
.copy-domain-btn-light::before{border-color:rgba(255,255,255,.8);box-shadow:4px -4px 0 -2px transparent,4px -4px 0 0 rgba(255,255,255,.8)}
.copy-domain-btn-light:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.42)}
.copy-domain-btn-light:hover::before{border-color:#fff;box-shadow:4px -4px 0 -2px transparent,4px -4px 0 0 #fff}
.dom-status.expiring{background:#dbeafe;color:#1d4ed8}
.dom-valen{vertical-align:middle}

/* --- Profile security overview ------------------------------------------- */
.security-overview{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;border-bottom:1px solid var(--border);background:#fff;
}
.security-overview-item{
  display:flex;gap:12px;align-items:flex-start;padding:18px 20px;border-right:1px solid var(--border);
}
.security-overview-item:last-child{border-right:none}
.security-overview-item strong{display:block;font-family:var(--display);font-size:13px;color:var(--navy);margin-bottom:3px}
.security-overview-item p{font-size:14px;color:var(--text-2);line-height:1.35}
.security-overview-item small{font-size:12px;color:var(--text-3);margin-top:4px}
.security-icon{
  width:34px;height:34px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  background:#f1f5f9;border:1px solid var(--border);color:var(--text-2);font-family:var(--display);font-weight:900;
}
.security-icon-login::before{content:'L'}
.security-icon-password::before{content:'*'}
.security-icon-2fa::before{content:'2'}
.security-overview-item.is-good .security-icon{background:#dcfce7;color:#166534;border-color:#86efac}
.security-overview-item.is-warning .security-icon{background:#fef3c7;color:#92400e;border-color:#fde68a}

/* --- Audit filters/search refinements ------------------------------------ */
.audit-search{display:flex}
.audit-clear{
  display:none;position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border:0;border-radius:7px;background:#e2e8f0;color:var(--text-2);cursor:pointer;font-size:18px;line-height:1;
}
.audit-clear.visible{display:inline-flex;align-items:center;justify-content:center}
.audit-clear:hover{background:#cbd5e1;color:var(--navy)}
.audit-search input{padding-right:46px!important}
.log-icon.epp{background:#e0f2fe;color:#075985}

/* logs.php 2030 audit trail polish */
.page-soft-icon{
  width:32px;
  height:32px;
  border-radius:9px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  background:linear-gradient(135deg,#e8f5ee,#eaf2ff);
  color:#1d6fd8;
  box-shadow:inset 0 0 0 1px rgba(34,197,94,.12);
}
.page-soft-icon svg{
  width:17px;
  height:17px;
  display:block;
}
.audit-page-icon{
  color:#166534;
}
.client-page-icon{
  background:#e8f7ee;
  color:#14532d;
}
.edit-domain-page-icon{
  background:#fff7ed;
  color:#c2410c;
}
.tools-page-icon{
  background:#e0f2fe;
  color:#0369a1;
}
.audit-readonly-note{
  display:flex;
  gap:10px;
  align-items:flex-start;
  margin:16px 20px 2px;
  padding:12px 14px;
  border:1px solid #bbf7d0;
  border-radius:14px;
  background:#f0fdf4;
  color:#14532d;
}
.audit-readonly-note span{
  width:22px;
  height:22px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  background:#14532d;
  color:#fff;
  font-family:var(--display);
  font-size:12px;
  font-weight:900;
}
.audit-readonly-note p{
  margin:0;
  color:#14532d;
  font-size:13px;
  line-height:1.5;
}
.audit-date-divider{
  display:flex;
  align-items:center;
  gap:12px;
  margin:8px 0 0;
  color:#64748b;
  font-family:var(--display);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.audit-date-divider::before,
.audit-date-divider::after{
  content:'';
  height:1px;
  flex:1;
  background:#e2e8f0;
}
.audit-date-divider span{
  padding:6px 10px;
  border:1px solid #e2e8f0;
  border-radius:999px;
  background:#fff;
}
.log-side{
  display:grid;
  justify-items:end;
  gap:8px;
}
.log-copy-btn{
  border:1px solid #dbeafe;
  border-radius:999px;
  background:#f8fbff;
  color:#1d4ed8;
  padding:5px 10px;
  font-family:var(--display);
  font-size:11px;
  font-weight:900;
  cursor:pointer;
  transition:background var(--t),border-color var(--t),color var(--t);
}
.log-copy-btn:hover,
.log-copy-btn.copied{
  border-color:#86efac;
  background:#dcfce7;
  color:#166534;
}
@media only screen and (max-width:767px){
  .audit-readonly-note{
    margin:14px 16px 0;
  }
  .log-side{
    grid-column:2;
    justify-items:start;
  }
}

/* --- Mobile action ergonomics -------------------------------------------- */
@media only screen and (max-width:767px){
  #dt2 tbody td.dom-name{display:block!important}
  .dom-name-wrap{justify-content:space-between;width:100%}
  .dom-name-text{white-space:normal;overflow-wrap:anywhere}
  #dt2 tbody td.dom-valen{display:block!important}
  #dt2 tbody td.dom-actions{
    display:grid!important;grid-template-columns:1fr 1fr;gap:8px!important;
  }
  #dt2 tbody td.dom-actions .gh_button{
    justify-content:center!important;width:100%;margin:0!important;padding:9px 10px!important;
  }
  .security-overview{grid-template-columns:1fr}
  .security-overview-item{border-right:none;border-bottom:1px solid var(--border)}
  .security-overview-item:last-child{border-bottom:none}
}

/* --- Focus ring for accessibility (keyboard users only) ------------------- */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
input[type=submit]:focus-visible,
.gh_button:focus-visible{
  outline:3px solid rgba(45,138,45,.35);
  outline-offset:2px;
  border-radius:var(--r);
}

/* --- Consistent form field focus state ------------------------------------ */
.input-text:focus,
input[type=email]:focus,
input[type=password]:focus,
input[type=text]:focus,
input[type=search]:focus,
textarea:focus,
select:focus{
  border-color:var(--accent)!important;
  box-shadow:0 0 0 4px rgba(45,138,45,.12)!important;
  background:#fff;
}

/* --- Button micro-interactions (additive — no overrides) ------------------ */
.gh_button,
input[type=submit]{
  transition:transform var(--t), box-shadow var(--t), background-color var(--t), color var(--t);
}
.gh_button:active,
input[type=submit]:active{transform:translateY(1px)}
.gh_button:disabled,
input[type=submit]:disabled{opacity:.55;cursor:not-allowed;transform:none}

/* --- Typography refinements ----------------------------------------------- */
.auth-flow-copy h2{letter-spacing:0;margin-bottom:8px}
.auth-flow-copy p{color:var(--text-2);font-size:15px;margin-top:4px}
.totp-step{letter-spacing:.3px;text-transform:uppercase;font-size:12px;font-weight:700;color:var(--accent-2)}

/* --- Link underline-on-hover for body prose ------------------------------- */
.box_c_content a:not(.gh_button):not(.mb_parent):hover{text-decoration:underline;text-underline-offset:3px}

/* --- Language selector in auth screens: tighter + aligned ----------------- */
.auth-lang-wrap{position:absolute;top:18px;right:18px;z-index:100}
.auth-lang-wrap .lang-select{
  background:rgba(255,255,255,.95);
  color:var(--navy);font-weight:600;font-size:13px;
  border:1px solid var(--border);border-radius:20px;padding:6px 28px 6px 12px;cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
}

/* --- Skip link for keyboard users (hidden visually until focus) ----------- */
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  position:fixed;top:12px;left:12px;width:auto;height:auto;
  padding:10px 16px;background:var(--navy);color:#fff;z-index:9999;
  border-radius:var(--r);font-weight:600;
}

/* --- Smoother scroll for in-page anchors ---------------------------------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* ==========================================================================
   Domain Search (landing page)
   ========================================================================== */
.domain-search-wrap{
  width:100%;max-width:520px;margin:24px auto 28px;
}
.domain-search-box{
  display:flex;gap:0;
  border:2px solid var(--border-2);border-radius:var(--r-lg);
  background:var(--bg-2);overflow:hidden;
  transition:border-color var(--t),box-shadow var(--t);
}
.domain-search-box:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-dim);
}
.domain-search-input{
  flex:1;border:0;outline:none;background:transparent;
  padding:12px 16px;font-size:16px;font-family:var(--font);
  color:var(--text);min-width:0;
}
.domain-search-input::placeholder{color:var(--text-3)}
.domain-search-btn{
  border-radius:0 calc(var(--r-lg) - 2px) calc(var(--r-lg) - 2px) 0 !important;
  margin:0 !important;white-space:nowrap;
  padding:12px 24px !important;font-size:15px !important;
}
.domain-search-hint{
  text-align:center;margin-top:8px;
  font-size:13px;color:var(--text-3);
}

/* --- Results --- */
.domain-search-results{
  display:none;margin-top:16px;
  border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--border);background:var(--bg-2);
  box-shadow:var(--sh);
}
.domain-search-results.active{display:block}

.dsr-row{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--border);
  transition:background var(--t);
}
.dsr-row:last-child{border-bottom:0}
.dsr-row:hover{background:var(--bg-3)}

.dsr-domain{
  flex:1;font-weight:600;font-size:15px;color:var(--text);
  font-family:var(--display);
}
.dsr-status{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.dsr-yes{color:var(--green)}
.dsr-no{color:var(--red)}
.dsr-unk{color:var(--orange)}

.dsr-register{
  padding:6px 16px !important;font-size:13px !important;
  border-radius:var(--r) !important;
}

.dsr-error{
  padding:16px 18px;text-align:center;
  color:var(--red);font-size:14px;
}

/* Loading skeleton pulse */
.dsr-loading .dsr-status{
  display:inline-block;width:72px;height:14px;
  background:var(--bg-3);border-radius:4px;
  animation:dsr-pulse 1.2s ease-in-out infinite;
}
@keyframes dsr-pulse{
  0%,100%{opacity:.4}
  50%{opacity:1}
}

/* Responsive */
@media(max-width:600px){
  .domain-search-wrap{max-width:100%}
  .domain-search-box{flex-direction:column;border-radius:var(--r)}
  .domain-search-input{padding:14px 16px}
  .domain-search-btn{
    border-radius:0 0 calc(var(--r) - 2px) calc(var(--r) - 2px) !important;
    padding:14px !important;
  }
  .dsr-row{flex-wrap:wrap;gap:8px;padding:12px 14px}
  .dsr-domain{width:100%;flex:none}
}

/* --- Tools / Watchlist ------------------------------------------------------- */
.tools-hero{
  padding:38px 32px;
  background:
    radial-gradient(circle at 82% 16%,rgba(34,197,94,.18),transparent 26%),
    radial-gradient(circle at 12% 88%,rgba(14,165,233,.12),transparent 28%),
    linear-gradient(135deg,#0f4b16 0%,#14532d 48%,#12395a 100%);
  color:#fff;
}
.tools-hero-kicker{
  display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:rgba(220,252,231,.16);
  color:#dcfce7;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px;
}
.tools-hero-title{font-family:var(--display);font-size:34px;font-weight:700;color:#fff;line-height:1.15;letter-spacing:0}
.tools-hero-copy{font-size:16px;color:rgba(255,255,255,.78);line-height:1.65;margin-top:10px;max-width:620px}
.watchlist-section{padding:0 32px 28px}
.watchlist-card{border:1.5px solid var(--border-2);border-radius:10px;overflow:hidden;margin-bottom:20px}
.watchlist-card-head{padding:18px 22px;border-bottom:1.5px solid var(--border-2);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.watchlist-card-head h2{font-family:var(--display);font-size:17px;font-weight:600;color:var(--text-1);margin:0}
.watchlist-card-head p{font-size:13px;color:var(--text-2);margin:2px 0 0}
.watchlist-add-form{display:flex;gap:8px;flex-wrap:wrap;padding:16px 22px;border-bottom:1.5px solid var(--border-2);background:var(--bg-3)}
.watchlist-add-form input[type=text]{flex:1;min-width:180px;padding:9px 14px;border:1.5px solid var(--border-2);border-radius:7px;font-size:14px;font-family:inherit;background:#fff;outline:none;transition:border-color .15s}
.watchlist-add-form input[type=text]:focus{border-color:var(--accent)}
.watchlist-add-form input[type=text]::placeholder{color:var(--text-3)}
.watchlist-add-btn{padding:9px 20px;border:none;border-radius:7px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;font-family:var(--display);cursor:pointer;white-space:nowrap;transition:opacity .15s}
.watchlist-add-btn:hover{opacity:.88}
.watchlist-add-btn:disabled{opacity:.5;cursor:not-allowed}
.watchlist-limit{font-size:12px;color:var(--text-3);padding:6px 22px 0;display:flex;align-items:center;gap:4px}
.watchlist-msg{padding:10px 22px;font-size:14px;border-bottom:1.5px solid var(--border-2)}
.watchlist-msg.ok{color:#166534;background:#dcfce7}
.watchlist-msg.err{color:#991b1b;background:#fee2e2}
.watchlist-table{width:100%;border-collapse:collapse;font-size:14px}
.watchlist-table th{text-align:left;padding:10px 14px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-3);background:var(--bg-3);border-bottom:1.5px solid var(--border-2)}
.watchlist-table td{padding:11px 14px;border-bottom:1px solid var(--border-2);vertical-align:middle}
.watchlist-table tr:last-child td{border-bottom:none}
.watchlist-domain{font-weight:600;color:var(--text-1)}
.watchlist-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.3px}
.watchlist-badge.available{background:#dcfce7;color:#166534}
.watchlist-badge.taken{background:#fee2e2;color:#991b1b}
.watchlist-badge.unknown{background:#f3f4f6;color:#6b7280}
.watchlist-badge.error{background:#fef3c7;color:#92400e}
.watchlist-badge.inactive{background:#f3f4f6;color:#9ca3af}
.watchlist-actions{display:flex;gap:6px;flex-wrap:wrap}
.watchlist-actions form{display:inline}
.watchlist-btn{padding:5px 12px;border:1.5px solid var(--border-2);border-radius:6px;background:#fff;font-size:12px;font-weight:600;font-family:var(--display);cursor:pointer;transition:all .15s;color:var(--text-2);text-decoration:none;display:inline-block;line-height:1.4}
.watchlist-btn:hover{border-color:var(--accent);color:var(--accent)}
.watchlist-btn.delete{color:#dc2626;border-color:#fecaca}
.watchlist-btn.delete:hover{background:#fee2e2;border-color:#dc2626}
.watchlist-delete-form.is-armed .watchlist-btn.delete{
  background:#fee2e2;border-color:#dc2626;color:#991b1b
}
.watchlist-btn.register{color:#166534;border-color:#bbf7d0;background:#f0fdf4}
.watchlist-btn.register:hover{background:#dcfce7;border-color:#166534}
.watchlist-empty{padding:32px 22px;text-align:center;color:var(--text-3);font-size:14px}
.watchlist-meta{font-size:12px;color:var(--text-3)}
@media(max-width:600px){
  .tools-hero{padding:24px 20px}
  .tools-hero-title{font-size:28px}
  .watchlist-section{padding:0 16px 20px}
  .watchlist-add-form{padding:12px 14px}
  .watchlist-add-form input[type=text]{min-width:120px}
  .watchlist-table th,.watchlist-table td{padding:9px 10px;font-size:13px}
  .watchlist-actions{gap:4px}
}

/* --- Print: hide nav, lang switcher, buttons ------------------------------ */
@media print{
  header,footer,.auth-lang-wrap,.lang-wrap,.gh_button,input[type=submit]{display:none!important}
  body{background:#fff;color:#000}
  .container{max-width:100%;padding:0}
}

/* --- Auth shared utility classes ----------------------------------------- */
.auth-alert{
  margin-bottom:16px;
  padding:14px 18px;
  border-radius:var(--r);
  font-weight:600;
  border:1.5px solid transparent;
}
.auth-alert.error{
  background:#fee2e2;
  border-color:#fca5a5;
  color:#991b1b;
}
.auth-alert.success{
  background:#dcfce7;
  border-color:#86efac;
  color:#166534;
}
.auth-help-text{
  font-size:13px;
  color:var(--text-3);
}
.auth-help-text.center{
  text-align:center;
}
.auth-center-note{
  text-align:center;
  margin-top:16px;
  font-size:13px;
  color:var(--text-3);
}
.auth-link{
  color:var(--accent-2);
  font-weight:600;
}
.auth-link-row{
  margin-top:8px;
  text-align:right;
}
.auth-stack-center{
  text-align:center;
  padding:12px 0 6px;
  max-width:620px;
  margin:0 auto;
}
.auth-stack-center p{
  font-size:15px;
  color:var(--text-2);
  margin-bottom:12px;
}
.auth-mb-14{
  margin-bottom:14px;
}
.auth-recaptcha-row{
  margin:12px 0;
}
.auth-recaptcha-wrap{
  display:flex;
  justify-content:center;
  width:100%;
  max-width:304px;
  margin:0 auto;
  overflow:hidden;
}
.auth-recaptcha-wrap > *{
  transform-origin:top left;
}

/* --- Profile + 2FA utility classes --------------------------------------- */
.u-ml-4{margin-left:4px}
.u-mb-10{margin-bottom:10px}
.u-mb-6{margin-bottom:6px}
.u-mt-12{margin-top:12px}

.profile-heading-meta{
  font-weight:400;
  font-size:14px;
  color:var(--text-2);
}

.profile-setup-title{
  font-size:16px;
  font-weight:700;
  margin-bottom:16px;
}

.profile-qr-manual{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:20px;
  width:200px;
  height:200px;
}
.profile-qr-icon{
  font-size:34px;
  margin-bottom:8px;
}
.profile-qr-copy{
  font-size:13px;
  line-height:1.5;
  color:var(--text-2);
}

/* profile.php 2026 security console */
.profile-security-console{
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);
  gap:20px;
  padding:24px;
  background:
    radial-gradient(circle at top left,rgba(34,197,94,.08),transparent 32%),
    linear-gradient(180deg,#f8fafc 0%,#fff 100%);
}
.profile-security-console.force-password-mode{
  grid-template-columns:minmax(0,760px);
}
.profile-security-card{
  border:1.5px solid #d7e3ef;
  border-radius:18px;
  background:#fff;
  overflow:hidden;
  box-shadow:0 18px 42px rgba(15,23,42,.07);
}
.profile-security-card-head{
  padding:22px 24px;
  border-bottom:1px solid #dbe7e0;
  background:
    radial-gradient(circle at top right,rgba(34,197,94,.12),transparent 36%),
    linear-gradient(135deg,#f8fffb 0%,#eefbf4 100%);
}
.profile-card-kicker{
  display:inline-flex;
  align-items:center;
  margin-bottom:10px;
  padding:7px 10px;
  border-radius:999px;
  background:#dcfce7;
  color:#166534;
  font-family:var(--display);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.profile-security-card-head h3{
  margin:0 0 6px;
  color:#052e16;
  font-family:var(--display);
  font-size:23px;
  line-height:1.15;
}
.profile-security-card-head p{
  margin:0;
  color:#334155;
  font-size:14px;
  line-height:1.55;
}
.profile-security-card-body{
  display:grid;
  grid-template-columns:minmax(0,1fr) 240px;
  gap:18px;
  padding:22px 24px;
}
.profile-security-card-body.single{
  display:block;
}
.profile-form{
  max-width:none;
}
.profile-form-row{
  margin-bottom:14px;
}
.profile-form-row label,
.profile-inline-form label{
  display:block;
  margin-bottom:7px;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.profile-password-hints{
  display:grid;
  gap:6px;
  min-height:0;
  margin:0;
  font-size:13px;
  line-height:1.35;
}
.profile-password-hints:empty{
  display:none;
}
.profile-rules-card{
  align-self:start;
  padding:16px;
  border:1px solid #bbf7d0;
  border-radius:16px;
  background:#f0fdf4;
}
.profile-rules-card h4{
  margin:0 0 12px;
  color:#14532d;
  font-family:var(--display);
  font-size:15px;
}
.profile-rule-list{
  display:grid;
  gap:8px;
}
.profile-rule-list div{
  position:relative;
  padding-left:20px;
  color:#334155;
  font-size:13px;
  line-height:1.4;
}
.profile-rule-list div::before{
  content:'';
  position:absolute;
  left:0;
  top:.48em;
  width:8px;
  height:8px;
  border-radius:999px;
  background:#16a34a;
}
.profile-rule-list .pw-hint-ok::before,
.profile-rule-list .pw-hint-bad::before{
  top:.05em;
  width:auto;
  height:auto;
  border-radius:0;
  background:transparent;
  font-weight:900;
}
.profile-rule-list .pw-hint-ok::before{
  content:'✓';
  color:#16a34a;
}
.profile-rule-list .pw-hint-bad::before{
  content:'✕';
  color:#dc2626;
}
.twofa-card.is-enabled .profile-security-card-head{
  background:
    radial-gradient(circle at top right,rgba(59,130,246,.14),transparent 36%),
    linear-gradient(135deg,#f8fbff 0%,#eff6ff 100%);
  border-bottom-color:#dbeafe;
}
.twofa-card.is-enabled .profile-card-kicker{
  background:#dbeafe;
  color:#1d4ed8;
}
.twofa-card.is-disabled .profile-security-card-head{
  background:
    radial-gradient(circle at top right,rgba(250,204,21,.16),transparent 36%),
    linear-gradient(135deg,#fffdf5 0%,#fffbeb 100%);
  border-bottom-color:#fde68a;
}
.twofa-card.is-disabled .profile-card-kicker{
  background:#fef3c7;
  color:#92400e;
}
.profile-status{
  border-radius:16px;
  margin-bottom:18px;
  padding:16px;
}
.profile-status-icon{
  width:36px;
  height:36px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:900;
  background:rgba(255,255,255,.72);
}
.profile-inline-form{
  gap:12px;
}
.profile-inline-form .input-text.narrow{
  border-radius:12px;
}
.profile-setup-flow .profile-qr-manual{
  height:auto;
  min-height:150px;
  background:#f8fafc;
}
@media(max-width:980px){
  .profile-security-console{
    grid-template-columns:1fr;
  }
}
@media(max-width:760px){
  .profile-security-console{
    padding:16px;
  }
  .profile-security-card-body{
    grid-template-columns:1fr;
    padding:18px;
  }
  .profile-security-card-head{
    padding:20px;
  }
}

.pw-hint-ok{color:#166534}
.pw-hint-bad{color:#991b1b}

/* --- Domains + Edit Domain utility classes -------------------------------- */
#dt2 tbody tr.dom-hidden{display:none!important}
#dt2 tbody tr.dom-paged-out{display:none!important}

.u-mt-10{margin-top:10px}
.u-mt-24{margin-top:24px}
.u-inline-none{display:none}

.domain-report-btn{
  font-size:12px;
  padding:6px 14px;
  text-decoration:none;
  background:#fff;
  color:#1e293b;
  border:1.5px solid #cbd5e1;
}
.domain-report-btn:hover{
  background:#f1f5f9;
}

.domain-page-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:32px;
  height:32px;
  padding:0 10px;
  border-radius:6px;
  font-size:13px;
  text-decoration:none;
  margin:2px;
  border:1.5px solid var(--border-2);
  background:#fff;
  color:inherit;
  cursor:pointer;
}
.domain-page-btn.active{
  border-color:var(--accent);
  background:var(--accent);
  color:#fff;
}
.domain-page-btn.disabled{
  color:#cbd5e1;
  cursor:default;
  pointer-events:none;
}

.th-sortable{
  cursor:pointer;
  user-select:none;
}

.domain-filter-banner.active{
  background:var(--bg-3);
  border-bottom-color:var(--border-2);
}
.domain-filter-banner.active .domain-filter-dot{
  background:var(--accent);
}
.domain-filter-banner.active .domain-filter-label{
  font-weight:700;
  color:var(--text-1);
}
.domain-filter-banner.active .domain-filter-dismiss{
  color:var(--text-2);
  border-color:var(--border-2);
}
.domain-filter-banner.info{
  background:#dbeafe;
  border-bottom-color:#93c5fd;
}
.domain-filter-banner.info .domain-filter-dot{background:#3b82f6}
.domain-filter-banner.info .domain-filter-label{
  font-weight:700;
  color:#1d4ed8;
}
.domain-filter-banner.info .domain-filter-dismiss{
  color:#1d4ed8;
  border-color:#93c5fd;
}
.domain-filter-banner.success{
  background:#dcfce7;
  border-bottom-color:#86efac;
}
.domain-filter-banner.success .domain-filter-dot{background:#22c55e}
.domain-filter-banner.success .domain-filter-label{
  font-weight:700;
  color:#166534;
}
.domain-filter-banner.success .domain-filter-dismiss{
  color:#166534;
  border-color:#86efac;
}
.domain-filter-banner.warning{
  background:#fef3c7;
  border-bottom-color:#fde68a;
}
.domain-filter-banner.warning .domain-filter-dot{background:#f59e0b}
.domain-filter-banner.warning .domain-filter-label{
  font-weight:700;
  color:#92400e;
}
.domain-filter-banner.warning .domain-filter-dismiss{
  color:#92400e;
  border-color:#fde68a;
}
.domain-filter-banner.danger{
  background:#fee2e2;
  border-bottom-color:#fca5a5;
}
.domain-filter-banner.danger .domain-filter-dot{background:#ef4444}
.domain-filter-banner.danger .domain-filter-label{
  font-weight:700;
  color:#991b1b;
}
.domain-filter-banner.danger .domain-filter-dismiss{
  color:#991b1b;
  border-color:#fca5a5;
}

/* NS entry cards */
.ns-section { margin-top:8px; }
.ns-section-title { font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin-bottom:10px; }
.ns-entry { display:flex;align-items:center;gap:0;border:1.5px solid var(--border-2);border-radius:8px;overflow:hidden;margin-bottom:8px;background:#fff;transition:border-color .15s; }
.ns-entry:focus-within { border-color:var(--accent); }
.ns-badge { flex-shrink:0;width:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-3);border-right:1.5px solid var(--border-2);align-self:stretch;font-size:11px;font-weight:700;color:var(--text-3);font-family:var(--display); }
.ns-host { flex:1;border:none;outline:none;padding:9px 12px;font-size:14px;font-family:inherit;background:transparent;min-width:0; }
.ns-ip-wrap { display:flex;align-items:center;border-left:1.5px solid var(--border-2);background:var(--bg-3); }
.ns-ip-wrap.is-hidden { display:none; }
.ns-ip-label { padding:0 8px 0 10px;font-size:11px;font-weight:600;color:var(--text-3);white-space:nowrap;text-transform:uppercase;letter-spacing:.3px; }
.ns-ip { border:none;outline:none;background:transparent;padding:9px 12px 9px 0;font-size:13px;font-family:inherit;width:140px;min-width:0;color:var(--text-2); }
@media(max-width:600px){ .ns-entry{flex-wrap:wrap} .ns-ip-wrap{border-left:none;border-top:1.5px solid var(--border-2);width:100%} .ns-ip{width:100%} }

/* --- Domain timeline ------------------------------------------------------ */
.domain-timeline-panel{
  margin-top:24px;
  border:1.5px solid #bfdbfe;
  border-radius:8px;
  background:linear-gradient(135deg,#fff 0%,#eff6ff 100%);
  overflow:hidden;
  box-shadow:0 14px 30px rgba(37,99,235,.07);
}
.domain-timeline-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  padding:18px 20px;
  border-bottom:1.5px solid #bfdbfe;
  background:rgba(255,255,255,.82);
}
.domain-timeline-head h3{
  font-family:var(--display);
  font-size:17px;
  color:#1e3a8a;
  margin:0 0 3px;
}
.domain-timeline-head p{
  font-size:13px;
  color:var(--text-2);
  margin:0;
}
.domain-timeline-link{
  flex-shrink:0;
  font-size:12px;
  font-weight:700;
  color:#1d4ed8;
  border:1.5px solid #bfdbfe;
  border-radius:7px;
  padding:6px 10px;
  background:#fff;
  text-decoration:none;
}
.domain-timeline-link:hover{
  border-color:#2563eb;
  color:#1e40af;
}
.domain-timeline-list{
  display:grid;
  gap:0;
}
.domain-timeline-item{
  display:grid;
  grid-template-columns:42px minmax(0,1fr) auto;
  gap:12px;
  align-items:flex-start;
  padding:15px 20px;
  border-bottom:1px solid #dbeafe;
  background:rgba(255,255,255,.72);
}
.domain-timeline-item:last-child{
  border-bottom:none;
}
.domain-timeline-mark{
  width:34px;
  height:34px;
  border-radius:9px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:var(--display);
  font-size:11px;
  font-weight:900;
  letter-spacing:.2px;
  background:#f1f5f9;
  color:var(--text-2);
}
.domain-timeline-item.contact .domain-timeline-mark{background:#ede9fe;color:#5b21b6}
.domain-timeline-item.nameserver .domain-timeline-mark{background:#dbeafe;color:#1d4ed8}
.domain-timeline-item.epp .domain-timeline-mark{background:#e0f2fe;color:#075985}
.domain-timeline-item.renewal .domain-timeline-mark{background:#dcfce7;color:#166534}
.domain-timeline-item.domain .domain-timeline-mark{background:#f1f5f9;color:#475569}
.domain-timeline-body{
  min-width:0;
}
.domain-timeline-meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:5px;
}
.domain-timeline-meta span{
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.35px;
  color:var(--text-3);
}
.domain-timeline-message{
  font-size:14px;
  color:var(--text);
  line-height:1.55;
  overflow-wrap:anywhere;
}
.domain-timeline-date{
  font-size:12px;
  color:var(--text-3);
  white-space:nowrap;
  padding-top:3px;
}
.domain-timeline-empty{
  padding:24px 20px;
  color:var(--text-3);
  text-align:center;
  font-size:14px;
}
@media(max-width:700px){
  .domain-timeline-head{display:block}
  .domain-timeline-link{display:inline-block;margin-top:10px}
  .domain-timeline-item{grid-template-columns:36px minmax(0,1fr)}
  .domain-timeline-date{grid-column:2;white-space:normal;padding-top:0}
}

/* Final scoped overrides for the redesigned domain editor.
   These intentionally live at the end so older global form rules cannot win. */
.domain-editor .domain-task-form .domain-fields{
  width:100%!important;
  max-width:560px!important;
}
.domain-editor .domain-task-form .domain-field{
  display:grid!important;
  gap:8px!important;
  margin:0 0 16px!important;
}
.domain-editor .domain-task-form .domain-field label{
  margin:0!important;
  color:#64748b!important;
  font-size:11px!important;
  font-weight:900!important;
  line-height:1.2!important;
  letter-spacing:.1em!important;
  text-transform:uppercase!important;
}
.domain-editor .domain-task-form .domain-field input.input-text,
.domain-editor .domain-task-form .domain-field input[type=text],
.domain-editor .domain-task-form .domain-field input[type=email],
.domain-editor .domain-task-form .domain-field input[type=tel]{
  display:block!important;
  width:100%!important;
  max-width:560px!important;
  height:44px!important;
  margin:0!important;
  padding:0 14px!important;
  border:1.5px solid #cbd5e1!important;
  border-radius:9px!important;
  background:#fff!important;
  box-sizing:border-box!important;
  color:#0f172a!important;
  font-size:14px!important;
  line-height:44px!important;
}
.domain-editor .domain-form-actions-smart{
  width:100%!important;
  max-width:560px!important;
}
.domain-editor .domain-form-actions-smart input[type=submit]{
  min-width:170px!important;
}
.domain-editor .domain-form-actions-smart input[type=submit]:disabled{
  background:#a7b0a6!important;
  border-color:#a7b0a6!important;
  color:#fff!important;
  cursor:not-allowed!important;
  opacity:1!important;
  box-shadow:none!important;
}
@media(max-width:767px){
  .domain-editor .domain-task-form .domain-fields,
  .domain-editor .domain-task-form .domain-field input.input-text,
  .domain-editor .domain-task-form .domain-field input[type=text],
  .domain-editor .domain-task-form .domain-field input[type=email],
  .domain-editor .domain-task-form .domain-field input[type=tel],
  .domain-editor .domain-form-actions-smart{
    max-width:100%!important;
  }
}

/* --- Generic utility classes --------------------------------------------- */
.u-overflow-hidden{overflow:hidden}
.u-ml-6{margin-left:6px}
.u-my-4{margin:4px 0}
.text-strong-white{color:#fff}
.text-success-strong{color:#166534}

/* --- Logs page controls --------------------------------------------------- */
.timeline-summary-label{margin:0}
.timeline-summary-select{
  border:1.5px solid var(--border-2);
  border-radius:6px;
  padding:4px 8px;
  font-size:13px;
  background:#fff;
}

/* --- EPP flow helpers ----------------------------------------------------- */
.epp-error-line{margin:4px 0}

/* Must remain last: production-safe override for edit-domain.php editor forms. */
.domain-editor .domain-task-layout{grid-template-columns:minmax(0,620px) 280px!important}
.domain-editor .domain-task-card{width:100%!important;max-width:620px!important}
.domain-editor .domain-task-form{width:100%!important;max-width:none!important}
.domain-editor .domain-task-form .domain-fields{width:100%!important;max-width:none!important}
.domain-editor .domain-task-form .domain-field input.input-text,
.domain-editor .domain-task-form .domain-field input[type=text],
.domain-editor .domain-task-form .domain-field input[type=email],
.domain-editor .domain-task-form .domain-field input[type=tel]{
  width:100%!important;max-width:none!important;height:44px!important;margin:0!important;padding:0 14px!important;box-sizing:border-box!important;
}
.domain-editor .domain-form-actions-smart{width:100%!important;max-width:none!important}
.domain-editor .domain-form-actions-smart input[type=submit]:disabled{display:none!important}
@media(max-width:767px){
  .domain-editor .domain-task-layout{grid-template-columns:1fr!important}
  .domain-editor .domain-task-card,
  .domain-editor .domain-task-form .domain-fields,
  .domain-editor .domain-task-form .domain-field input.input-text,
  .domain-editor .domain-task-form .domain-field input[type=text],
  .domain-editor .domain-task-form .domain-field input[type=email],
  .domain-editor .domain-task-form .domain-field input[type=tel],
  .domain-editor .domain-form-actions-smart{max-width:100%!important}
}

/* Final simplification: edit-domain.php should be a single clean work card. */
.domain-editor .domain-task-layout{
  display:block!important;
}
.domain-editor .domain-guidance-card:not(.warning){
  display:none!important;
}
.domain-editor .domain-task-card{
  width:100%!important;
  max-width:none!important;
}
.domain-editor .domain-task-form{
  width:100%!important;
  max-width:none!important;
  padding:26px!important;
}
.domain-editor .domain-task-form .domain-fields{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:18px!important;
  width:100%!important;
  max-width:none!important;
}
.domain-editor .domain-task-form .domain-field{
  margin:0!important;
}
.domain-editor .domain-task-form .domain-field label{
  display:block!important;
  margin:0 0 9px!important;
}
.domain-editor .domain-task-form .domain-field input.input-text,
.domain-editor .domain-task-form .domain-field input[type=text],
.domain-editor .domain-task-form .domain-field input[type=email],
.domain-editor .domain-task-form .domain-field input[type=tel]{
  width:100%!important;
  max-width:none!important;
}
.domain-editor .domain-form-actions-smart{
  width:100%!important;
  max-width:none!important;
  justify-content:flex-start!important;
  gap:18px!important;
}
.domain-editor .domain-form-actions-smart input[type=submit]:disabled{
  display:none!important;
}
@media(max-width:900px){
  .domain-editor .domain-task-form .domain-fields{
    grid-template-columns:1fr!important;
  }
}
@media(max-width:767px){
  .domain-editor .domain-task-form{
    padding:18px!important;
  }
}

/* edit-domain.php polish: calmer task card, DNS-style rows, compact notes. */
.domain-editor{
  gap:20px!important;
}
.domain-editor .domain-editor-nav{
  padding:7px!important;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)!important;
  box-shadow:0 10px 28px rgba(15,23,42,.06)!important;
}
.domain-editor .domain-editor-tab{
  min-height:43px!important;
  border-radius:12px!important;
}
.domain-editor .domain-editor-tab.active{
  background:linear-gradient(135deg,#06470d 0%,#0f5818 100%)!important;
  box-shadow:0 12px 26px rgba(6,71,13,.22)!important;
}
.domain-editor .domain-task-card{
  border-color:#d7e3ef!important;
  box-shadow:0 18px 46px rgba(15,23,42,.08)!important;
}
.domain-editor .domain-task-head{
  padding:24px 26px!important;
  background:
    radial-gradient(circle at top right,rgba(34,197,94,.16),transparent 34%),
    linear-gradient(135deg,#f8fffb 0%,#edfdf5 100%)!important;
}
.domain-editor .domain-task-head h3{
  font-size:24px!important;
}
.domain-editor .domain-task-form{
  padding:28px 26px!important;
}
.domain-editor [data-ns-form] .ns-section{
  display:grid!important;
  gap:10px!important;
  margin:0!important;
}
.domain-editor [data-ns-form] .ns-entry{
  display:grid!important;
  grid-template-columns:42px minmax(0,1fr)!important;
  gap:10px!important;
  align-items:center!important;
  border:1px solid #d8e4ef!important;
  border-radius:14px!important;
  background:#fff!important;
  padding:8px!important;
  box-shadow:0 8px 20px rgba(15,23,42,.04)!important;
}
.domain-editor [data-ns-form] .ns-entry.has-child-ip{
  grid-template-columns:42px minmax(0,1fr) 190px!important;
}
.domain-editor [data-ns-form] .ns-entry.u-inline-none{
  display:none!important;
}
.domain-editor [data-ns-form] .ns-entry.has-error{
  border-color:#fca5a5!important;
  box-shadow:0 0 0 4px rgba(239,68,68,.08)!important;
}
.domain-editor [data-ns-form] .ns-entry:focus-within{
  border-color:#16a34a!important;
  box-shadow:0 0 0 4px rgba(22,163,74,.1)!important;
}
.domain-editor [data-ns-form] .ns-badge{
  width:34px!important;
  height:34px!important;
  border-radius:10px!important;
  background:#ecfdf5!important;
  color:#166534!important;
  font-weight:900!important;
  border:1px solid #bbf7d0!important;
}
.domain-editor [data-ns-form] .ns-host,
.domain-editor [data-ns-form] .ns-ip{
  height:38px!important;
  border:0!important;
  border-radius:10px!important;
  background:#f8fafc!important;
  padding:0 13px!important;
  font-size:14px!important;
  box-shadow:none!important;
}
.domain-editor [data-ns-form] .ns-host:focus,
.domain-editor [data-ns-form] .ns-ip:focus{
  background:#fff!important;
  outline:2px solid rgba(22,163,74,.22)!important;
}
.domain-editor [data-ns-form] .ns-ip-wrap{
  display:flex!important;
  align-items:center!important;
  grid-column:3!important;
  border:0!important;
  background:#eef6ff!important;
  border-radius:10px!important;
  overflow:hidden!important;
  box-shadow:inset 0 0 0 1px #bfdbfe!important;
  max-width:none!important;
}
.domain-editor [data-ns-form] .ns-ip-wrap.is-hidden{
  display:none!important;
}
.domain-editor [data-ns-form] .ns-ip-label{
  height:38px!important;
  display:flex!important;
  align-items:center!important;
  flex:0 0 auto!important;
  padding:0 11px!important;
  color:#1d4ed8!important;
  font-weight:900!important;
  background:#eef6ff!important;
  border-right:1px solid #dbeafe!important;
}
.domain-editor [data-ns-form] .ns-ip{
  min-width:0!important;
  flex:1 1 auto!important;
  background:#fff!important;
}
.domain-editor [data-ns-form] .ns-ip::placeholder{
  color:#94a3b8!important;
}
.domain-editor [data-ns-form] .ns-ip-wrap{
  width:100%!important;
}
.domain-editor [data-ns-form] .ns-ip-label{
  display:flex!important;
}
.domain-editor [data-ns-form] .ns-ip{
  width:100%!important;
  max-width:none!important;
  height:38px!important;
  border:0!important;
  border-radius:0!important;
  background:#fff!important;
  padding:0 13px!important;
  color:#0f172a!important;
}
.domain-editor [data-ns-form] .ns-row-error{
  display:none;
  grid-column:2 / -1;
  color:#b91c1c;
  font-size:12px;
  font-weight:800;
  padding:0 4px 2px;
}
.domain-editor [data-ns-form] .ns-entry.has-error .ns-row-error{
  display:block;
}
.domain-editor .save-state{
  display:inline-flex!important;
  align-items:center!important;
  max-width:100%!important;
  min-height:34px!important;
  padding:8px 12px!important;
  border:1px dashed #bfd4c4!important;
  border-radius:999px!important;
  background:#fbfffc!important;
  color:#52665a!important;
  line-height:1.35!important;
}
.domain-editor .domain-task-form.has-unsaved .save-state{
  border-style:solid!important;
  border-color:#86efac!important;
  background:#dcfce7!important;
  color:#166534!important;
}
.domain-editor .domain-guidance-card.warning{
  margin-top:14px!important;
  border-radius:16px!important;
  border-color:#fed7aa!important;
  background:#fff7ed!important;
  box-shadow:none!important;
}
.domain-editor .domain-guidance-card.warning strong{
  color:#9a3412!important;
}
.domain-editor .domain-guidance-card.warning p{
  color:#7c2d12!important;
}
.domain-editor .domain-alert,
.domain-edit-shell > .domain-alert{
  border-radius:16px!important;
  box-shadow:0 12px 28px rgba(22,101,52,.08)!important;
}
@media(max-width:900px){
  .domain-editor [data-ns-form] .ns-entry{
    grid-template-columns:38px minmax(0,1fr)!important;
  }
  .domain-editor [data-ns-form] .ns-entry.has-child-ip{
    grid-template-columns:38px minmax(0,1fr)!important;
  }
  .domain-editor [data-ns-form] .ns-ip-wrap{
    grid-column:2!important;
    max-width:240px!important;
  }
}

/* ═══════════════════════════════════════════════════════════════════════
   Unified edit-domain page (single-form layout)
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Form shell ── */
.domain-renewal-panel{
  --renew-accent:#2563eb;
  --renew-accent-dark:#1e3a8a;
  --renew-surface:#eff6ff;
  --renew-surface-2:#f8fbff;
  --renew-border:#bfdbfe;
  position:relative;
  isolation:isolate;
  min-width:0;
  margin:0 0 18px;
  padding:18px 20px;
  border:1.5px solid var(--renew-border);
  border-radius:8px;
  background:linear-gradient(135deg,#fff 0%,var(--renew-surface) 62%,var(--renew-surface-2) 100%);
  box-shadow:0 14px 30px rgba(15,23,42,.06);
  overflow:hidden;
}
.domain-renewal-panel::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:7px;
  background:linear-gradient(180deg,var(--renew-accent),var(--renew-accent-dark));
}
.domain-renewal-stable{
  --renew-accent:#16a34a;
  --renew-accent-dark:#166534;
  --renew-surface:#f0fdf4;
  --renew-surface-2:#dcfce7;
  --renew-border:#bbf7d0;
}
.domain-renewal-warning{
  --renew-accent:#d97706;
  --renew-accent-dark:#92400e;
  --renew-surface:#fffbeb;
  --renew-surface-2:#fef3c7;
  --renew-border:#fde68a;
}
.domain-renewal-urgent{
  --renew-accent:#dc2626;
  --renew-accent-dark:#991b1b;
  --renew-surface:#fff7f7;
  --renew-surface-2:#fee2e2;
  --renew-border:#fecaca;
}
.domain-renewal-info{
  --renew-accent:#2563eb;
  --renew-accent-dark:#1e3a8a;
  --renew-surface:#eff6ff;
  --renew-surface-2:#dbeafe;
  --renew-border:#bfdbfe;
}
.domain-renewal-head,
.domain-renewal-grid{
  position:relative;
  z-index:1;
  min-width:0;
}
.domain-renewal-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-left:6px;
}
.domain-renewal-kicker,
.domain-renewal-meta-card span,
.domain-renewal-state span{
  display:block;
  color:#64748b;
  font-size:10.5px;
  font-weight:900;
  letter-spacing:.09em;
  line-height:1.2;
  text-transform:uppercase;
}
.domain-renewal-head h3{
  margin:6px 0 4px;
  color:var(--renew-accent-dark);
  font-family:var(--display);
  font-size:18px;
  font-weight:900;
  line-height:1.2;
}
.domain-renewal-head p{
  margin:0;
  color:#475569;
  font-size:13px;
  font-weight:700;
  line-height:1.45;
}
.domain-renewal-badge{
  flex-shrink:0;
  max-width:220px;
  padding:7px 11px;
  border:1px solid var(--renew-border);
  border-radius:999px;
  background:rgba(255,255,255,.82);
  color:var(--renew-accent-dark);
  font-size:11px;
  font-weight:900;
  line-height:1.2;
  text-align:center;
  text-transform:uppercase;
  overflow-wrap:anywhere;
}
.domain-renewal-grid{
  display:grid;
  grid-template-columns:minmax(240px,1.35fr) repeat(3,minmax(120px,.65fr));
  gap:10px;
  margin-top:14px;
  margin-left:6px;
}
.domain-renewal-state,
.domain-renewal-meta-card{
  min-width:0;
  border:1px solid rgba(203,213,225,.78);
  border-radius:8px;
  background:rgba(255,255,255,.78);
}
.domain-renewal-state{
  padding:14px;
}
.domain-renewal-state strong{
  display:block;
  margin-top:7px;
  color:#0f172a;
  font-family:var(--display);
  font-size:16px;
  font-weight:900;
  line-height:1.25;
  overflow-wrap:anywhere;
}
.domain-renewal-state p{
  margin:6px 0 0;
  color:#475569;
  font-size:13px;
  font-weight:700;
  line-height:1.45;
}
.domain-renewal-meta-card{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:12px;
}
.domain-renewal-meta-card strong{
  display:block;
  margin-top:6px;
  color:#0f172a;
  font-family:var(--display);
  font-size:14px;
  font-weight:900;
  line-height:1.25;
  overflow-wrap:anywhere;
}
.domain-unified-form{
  display:grid;gap:16px;
}

/* ── Sections (fieldsets) — shared ── */
.domain-section{
  --section-accent:var(--accent);
  --section-accent-dark:var(--navy);
  --section-surface:#f8fffb;
  --section-surface-2:#eefbf4;
  --section-border:#bbf7d0;
  --section-chip:#dcfce7;
  --section-focus:rgba(45,138,45,.13);
  --section-glow:rgba(22,101,52,.07);
  position:relative;
  isolation:isolate;
  overflow:hidden;
  min-width:0;
  border:none;margin:0;
  padding:22px 24px 20px 28px;
  border-radius:8px;
  background:
    linear-gradient(135deg,#fff 0%,var(--section-surface) 48%,var(--section-surface-2) 100%);
  box-shadow:inset 0 0 0 1.5px var(--section-border),0 14px 30px var(--section-glow);
  transition:box-shadow .2s ease,transform .2s ease;
}
.domain-section::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:7px;
  background:linear-gradient(180deg,var(--section-accent),var(--section-accent-dark));
  z-index:2;
}
.domain-section::after{
  content:'';
  position:absolute;right:14px;top:14px;width:96px;height:42px;
  background:repeating-linear-gradient(135deg,var(--section-border) 0 1px,transparent 1px 8px);
  opacity:.26;pointer-events:none;
  z-index:0;
}
.domain-section > *{position:relative;z-index:1}
.domain-section[data-section="ns"]{
  --section-accent:#0f766e;
  --section-accent-dark:#115e59;
  --section-surface:#f0fdfa;
  --section-surface-2:#ccfbf1;
  --section-border:#99f6e4;
  --section-chip:#ccfbf1;
  --section-focus:rgba(15,118,110,.14);
  --section-glow:rgba(15,118,110,.08);
}
.domain-section[data-section="admin"]{
  --section-accent:#2563eb;
  --section-accent-dark:#1e3a8a;
  --section-surface:#eff6ff;
  --section-surface-2:#dbeafe;
  --section-border:#bfdbfe;
  --section-chip:#dbeafe;
  --section-focus:rgba(37,99,235,.14);
  --section-glow:rgba(37,99,235,.08);
}
.domain-section[data-section="tech"]{
  --section-accent:#d97706;
  --section-accent-dark:#92400e;
  --section-surface:#fffbeb;
  --section-surface-2:#fef3c7;
  --section-border:#fde68a;
  --section-chip:#fef3c7;
  --section-focus:rgba(217,119,6,.16);
  --section-glow:rgba(180,83,9,.08);
}
.domain-section.has-changes{
  box-shadow:inset 0 0 0 2px var(--section-accent),0 18px 38px var(--section-glow);
}
.domain-section-legend{
  display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;
  float:left;
  width:100%;
  font-family:var(--display);font-size:17px;font-weight:700;color:var(--section-accent-dark);
  padding:0;margin:0 0 14px;
}
.domain-section-legend + *{clear:both}
.domain-section-icon{
  width:34px;height:34px;flex-shrink:0;
  padding:8px;border-radius:8px;
  background:var(--section-chip);
  stroke:var(--section-accent);
  box-shadow:inset 0 0 0 1px var(--section-border);
}
/* Badge inside legend (NS section) */
.domain-section-badge{
  margin-left:0;justify-self:end;
  font-family:var(--font);font-size:10.5px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--section-accent-dark);background:rgba(255,255,255,.78);
  padding:4px 10px;border:1px solid var(--section-border);border-radius:100px;
}
/* Badge on its own line (contact cards — saves horizontal space) */
.domain-section-badge-block{
  display:inline-block;
  font-family:var(--font);font-size:10.5px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--section-accent-dark);background:rgba(255,255,255,.78);
  padding:4px 10px;border:1px solid var(--section-border);border-radius:100px;
  margin:0 0 14px;
}
.domain-section-intro{
  font-size:13px;line-height:1.55;color:var(--text-2);
  margin:0 0 14px;
}

/* ── Contacts row: two cards side by side ── */
.domain-contacts-row{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  border-bottom:none;
}
.domain-contacts-row .domain-section-card{
  border-bottom:none;
  padding:22px 24px 20px 28px;
}
.domain-contacts-row .domain-section-card:first-child{
  border-right:none;
}

/* Contact fields — stacked vertically inside each card */
.domain-fields-stack{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.domain-section .domain-field label{
  display:block;font-size:11.5px;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);
  margin-bottom:5px;
}
.domain-section .domain-field .input-text,
.domain-section .domain-field input[type=text],
.domain-section .domain-field input[type=email],
.domain-section .domain-field input[type=tel]{
  display:block;width:100%;
  font-family:var(--font);font-size:14.5px;
  padding:9px 13px;
  border:1.5px solid var(--border-2);border-radius:8px;
  background:#fff;color:var(--text);
  transition:border-color .15s,box-shadow .15s;
}
.domain-section .domain-field input:focus{
  border-color:var(--section-accent);
  box-shadow:0 0 0 3px var(--section-focus);
  outline:none;
}

/* ── NS section ── */
.domain-unified-form .ns-section{margin-top:4px}

/* Override the global .ns-entry flex layout — we need block stacking */
.domain-unified-form .ns-entry{
  display:block;
  border:1.5px solid var(--section-border);border-radius:8px;
  overflow:hidden;margin-bottom:7px;background:#fff;
  transition:border-color .15s;
}
.domain-unified-form .ns-entry:focus-within{border-color:var(--section-accent)}
.domain-unified-form .ns-entry.u-inline-none{display:none}
.domain-unified-form .ns-entry.has-error{border-color:var(--red)}

/* Main row: badge + hostname */
.domain-unified-form .ns-main-row{
  display:grid;grid-template-columns:34px minmax(0,1fr);
}
.domain-unified-form .ns-badge{
  display:flex;align-items:center;justify-content:center;
  width:auto;align-self:auto;flex-shrink:initial;
  background:var(--section-chip);border-right:1.5px solid var(--section-border);
  font-size:11px;font-weight:700;color:var(--section-accent-dark);font-family:var(--display);
}
.domain-unified-form .ns-host{
  border:none;outline:none;padding:9px 13px;
  font-family:var(--font);font-size:14px;color:var(--text);
  background:transparent;width:100%;min-width:0;
  flex:initial;
}
.domain-unified-form .ns-host:focus{background:rgba(45,138,45,.03)}
.domain-section[data-section="ns"] .ns-host:focus{background:rgba(15,118,110,.05)}

/* IP row: appears below the hostname when NS is a child host */
.domain-unified-form .ns-ip-row{
  display:flex;align-items:center;gap:0;
  border-top:1px dashed var(--section-border);
  background:linear-gradient(135deg,rgba(255,255,255,.72) 0%,var(--section-surface) 100%);
  padding:0 0 0 34px;
}
.domain-unified-form .ns-ip-row.is-hidden{display:none}
.domain-unified-form .ns-ip-label{
  padding:0 2px 0 14px;font-size:10px;font-weight:800;
  color:var(--section-accent);letter-spacing:.08em;white-space:nowrap;
  text-transform:uppercase;
  border:none;display:inline;width:auto;
}
.domain-unified-form .ns-ip{
  border:none;outline:none;
  padding:7px 13px;
  font-family:'SF Mono',ui-monospace,'Cascadia Mono',Menlo,monospace;
  font-size:13px;color:var(--text);letter-spacing:.02em;
  background:transparent;width:100%;min-width:0;
}
.domain-unified-form .ns-ip:focus{background:rgba(45,138,45,.04)}
.domain-section[data-section="ns"] .ns-ip:focus{background:rgba(15,118,110,.05)}
.domain-unified-form .ns-ip::placeholder{
  font-family:var(--font);color:var(--text-3);font-size:12.5px;letter-spacing:0;
}

/* Error row */
.domain-unified-form .ns-row-error{
  display:none;
  padding:5px 14px 6px 48px;
  font-size:12px;color:var(--red);font-weight:600;background:#fff5f5;
  border-top:1px solid #fecaca;
}
.domain-unified-form .ns-entry.has-error .ns-row-error{display:block}

/* ── Section change preview ── */
.domain-unified-form .section-change-preview{
  display:none;
  margin-top:14px;padding:12px;
  background:rgba(255,255,255,.48);border:1px dashed var(--section-border);border-radius:8px;
  gap:8px;
}
.domain-section.has-changes .section-change-preview{display:grid;gap:8px}
.domain-unified-form .section-change-item{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 10px;
  padding:8px 12px;
  background:rgba(255,255,255,.82);border-radius:8px;
}
.domain-unified-form .section-change-item + .section-change-item{
  border-top:none;padding-top:8px;
}
.domain-unified-form .section-change-name{
  font-size:10.5px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:#64748b;
  min-width:100px;
}
.domain-unified-form .section-change-old{font-size:12.5px;line-height:1.35;word-break:break-word;color:#94a3b8}
.domain-unified-form .section-change-new{font-size:12.5px;line-height:1.35;word-break:break-word;color:var(--section-accent-dark);font-weight:800}
.domain-unified-form .section-change-old::before{content:'→ ';color:var(--border-2)}

/* ── Sticky save bar ── */
.domain-save-bar{
  position:sticky;bottom:0;z-index:50;
  padding:12px 24px;
  background:var(--bg-3);
  border-top:1px solid var(--border);
  transition:background .25s,box-shadow .25s;
}
.domain-save-bar.is-active{
  background:#fff;
  box-shadow:0 -4px 24px rgba(0,0,0,.08);
}
.domain-save-bar-inner{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.domain-save-status{
  font-size:13px;font-weight:700;color:var(--text-3);
  transition:color .2s;
}
.domain-save-bar.is-active .domain-save-status{color:var(--navy)}
.domain-save-btn{
  font-family:var(--display);font-size:14.5px;font-weight:700;
  padding:10px 30px;border-radius:8px;border:none;cursor:pointer;
  color:#fff;background:var(--accent);
  transition:background .15s,opacity .15s,transform .15s;
  white-space:nowrap;
}
.domain-save-btn:hover:not(:disabled){background:var(--navy);transform:translateY(-1px)}
.domain-save-btn:disabled{
  opacity:.35;cursor:default;
}

/* ── Notice bar ── */
.domain-notice-bar{
  display:flex;align-items:flex-start;gap:10px;
  padding:13px 20px;margin:14px 0 0;
  font-size:12.5px;line-height:1.6;color:var(--text-2);
  background:var(--bg-3);border-radius:8px;
}
.domain-notice-bar[hidden]{display:none!important}
.domain-notice-icon{width:16px;height:16px;flex-shrink:0;stroke:var(--text-3);margin-top:2px}

/* ── Responsive ── */
@media(max-width:800px){
  .domain-renewal-grid{
    grid-template-columns:1fr;
  }
  .domain-renewal-head{
    display:block;
  }
  .domain-renewal-badge{
    display:inline-block;
    margin-top:10px;
    max-width:100%;
  }
  .domain-contacts-row{grid-template-columns:1fr}
  .domain-contacts-row .domain-section-card:first-child{
    border-right:none;
    border-bottom:none;
  }
}
@media(max-width:600px){
  .domain-section{padding:18px 16px 16px 22px}
  .domain-contacts-row .domain-section-card{padding:18px 16px 16px 22px}
  .domain-section-legend{grid-template-columns:auto minmax(0,1fr);gap:9px}
  .domain-section-badge{grid-column:2;justify-self:start}
  .domain-section::after{width:70px;height:34px;right:10px;top:12px}
  .domain-save-bar{padding:10px 16px}
  .domain-save-bar-inner{flex-direction:column;align-items:stretch;gap:8px}
  .domain-save-btn{width:100%;text-align:center}
  .domain-unified-form .section-change-item{flex-direction:column;gap:2px}
  .domain-unified-form .ns-ip-row{padding-left:0}
  .domain-unified-form .ns-ip-label{padding-left:12px}
  .domain-unified-form .section-change-name{min-width:auto}
}

/* client.php registry record view */
.client-registry-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:20px;
  align-items:start;
}
.client-registry-card,
.client-change-card{
  border:1.5px solid #d7e3ef;
  border-radius:18px;
  background:#fff;
  box-shadow:0 18px 42px rgba(15,23,42,.07);
  overflow:hidden;
}
.client-registry-head{
  padding:22px 26px;
  background:
    radial-gradient(circle at top right,rgba(34,197,94,.12),transparent 36%),
    linear-gradient(135deg,#f8fffb 0%,#eefbf4 100%);
  border-bottom:1px solid #dbe7e0;
}
.client-registry-eyebrow{
  display:inline-flex;
  align-items:center;
  margin-bottom:10px;
  padding:7px 10px;
  border-radius:999px;
  background:#dcfce7;
  color:#166534;
  font-family:var(--display);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.client-registry-head h3{
  margin:0 0 6px;
  color:#052e16;
  font-family:var(--display);
  font-size:23px;
  line-height:1.15;
}
.client-registry-head p{
  margin:0;
  max-width:620px;
  color:#334155;
  font-size:14px;
  line-height:1.55;
}
.client-record-field span{
  display:block;
  margin-bottom:6px;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.client-record-sections{
  display:grid;
  gap:0;
}
.client-record-section{
  padding:24px 26px;
  border-bottom:1px solid #e2e8f0;
}
.client-record-section:last-child{
  border-bottom:0;
}
.client-record-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:14px;
}
.client-record-wide{
  grid-column:1 / -1;
}
.client-record-field{
  min-height:72px;
  padding:15px 16px;
  border:1px solid #dbe7f0;
  border-radius:14px;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
}
.client-record-field strong{
  display:block;
  color:#0f172a;
  font-size:15px;
  line-height:1.45;
  white-space:nowrap;
  overflow:hidden;
  /* Auto-shrink (only when needed) is applied by JS in client.php — see
     the script tagged `data-fit-text` at the bottom of that file. The
     script ratchets font-size down in 0.5px steps until the text fits
     the cell, with a floor of ~12px. Short values stay at the full 15px. */
}
.client-change-card{
  position:sticky;
  top:18px;
  padding:22px;
  isolation:isolate;
  background:
    radial-gradient(circle at top left,rgba(250,204,21,.18),transparent 34%),
    linear-gradient(180deg,#fffdf5 0%,#fff 100%);
  border-color:#fde68a;
}
.client-change-card::before{
  content:'';
  position:absolute;
  inset:0 0 auto;
  height:72px;
  z-index:0;
  background:linear-gradient(135deg,rgba(254,243,199,.82),rgba(255,251,235,0));
}
.client-change-card > *{
  position:relative;
  z-index:1;
}
.client-change-callout-head{
  display:grid;
  grid-template-columns:38px minmax(0,1fr);
  gap:12px;
  align-items:center;
  margin-bottom:12px;
}
.client-change-icon{
  width:38px;
  height:38px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fef3c7;
  color:#92400e;
  font-family:var(--display);
  font-weight:900;
  box-shadow:inset 0 0 0 1px rgba(245,158,11,.16);
}
.client-change-card h3{
  margin:0;
  color:#713f12;
  font-family:var(--display);
  font-size:17px;
  line-height:1.18;
}
.client-change-card p{
  margin:0 0 16px;
  color:#7c2d12;
  line-height:1.55;
}
.client-change-steps{
  display:grid;
  gap:10px;
  margin-bottom:16px;
}
.client-change-steps div{
  display:grid;
  grid-template-columns:28px minmax(0,1fr);
  gap:10px;
  align-items:start;
  color:#334155;
  font-size:13px;
  line-height:1.45;
}
.client-change-steps span{
  width:24px;
  height:24px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#14532d;
  color:#fff;
  font-size:12px;
  font-weight:900;
}
.client-change-note{
  margin-top:14px;
  padding-top:14px;
  border-top:1px dashed #fbbf24;
  color:#78350f;
  font-size:13px;
  line-height:1.55;
}
.client-change-link{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:9px 13px;
  border-radius:12px;
  background:#14532d;
  color:#fff!important;
  font-size:13px;
  font-weight:900;
  text-align:center;
  text-decoration:none!important;
  box-shadow:0 10px 20px rgba(20,83,45,.16);
}
.client-change-link:hover{
  background:#0f3f22;
  color:#fff!important;
}
@media(max-width:980px){
  .client-registry-layout{
    grid-template-columns:1fr;
  }
  .client-change-card{
    position:static;
  }
}
@media(max-width:700px){
  .client-registry-head{
    padding:20px;
  }
  .client-record-grid{
    grid-template-columns:1fr;
  }
  .client-record-section{
    padding:18px;
  }
  .client-record-field strong{
    white-space:normal!important;
    overflow:visible!important;
    overflow-wrap:anywhere;
  }
}

/* index.php: modern dashboard overview */
.dashboard-home{
  gap:16px;
}
.dashboard-overview-card,
.dashboard-status-card,
.dashboard-home .dashboard-main-grid .box_c{
  border-color:#d7e3ef;
  box-shadow:0 20px 54px rgba(15,23,42,.08);
}
.dashboard-page-icon{
  background:#e7f8ee!important;
  color:#0f7a35!important;
}
.dashboard-home .dashboard-hero{
  background:
    radial-gradient(circle at 82% 16%,rgba(34,197,94,.18),transparent 26%),
    radial-gradient(circle at 12% 88%,rgba(14,165,233,.12),transparent 28%),
    linear-gradient(135deg,#0f4b16 0%,#14532d 48%,#12395a 100%);
  min-height:0;
}
.dashboard-home .dashboard-hero-main{
  padding:28px 30px;
}
.dashboard-home .dashboard-kicker{
  background:rgba(220,252,231,.16);
  color:#dcfce7;
}
.dashboard-home .dashboard-hero-title{
  max-width:640px;
  font-size:30px;
  letter-spacing:0;
}
.dashboard-home .dashboard-hero-copy{
  max-width:620px;
  font-size:15px;
  line-height:1.55;
}
.dashboard-home .dashboard-hero-meta{
  margin-top:24px;
}
.dashboard-home .dashboard-pill{
  min-height:40px;
  padding:9px 14px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.12);
}
.dashboard-home .dashboard-compact-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:22px;
}
.dashboard-home .dashboard-compact-stats .dashboard-stat{
  min-height:82px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:14px 12px;
  position:relative;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  background:rgba(255,255,255,.1);
  color:#fff;
  text-align:left;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  overflow:hidden;
}
.dashboard-home .dashboard-compact-stats .dashboard-stat:hover{
  background:rgba(255,255,255,.16);
  transform:translateY(-1px);
}
.dashboard-home .dashboard-compact-stats .dashboard-stat-num{
  margin:0 0 6px;
  color:#fff!important;
  font-size:27px;
  line-height:1;
}
.dashboard-home .dashboard-compact-stats .dashboard-stat-label{
  color:rgba(255,255,255,.74);
  font-size:10px;
  line-height:1.25;
}
.dashboard-home .dashboard-compact-stats .dashboard-stat::before{
  content:'';
  position:static;
  width:24px;
  height:3px;
  display:block;
  left:auto;
  top:auto;
  margin-bottom:10px;
  border-radius:999px;
  background:#22c55e;
}
.dashboard-home .dashboard-compact-stats .dashboard-stat.s-expiring::before{background:#60a5fa}
.dashboard-home .dashboard-compact-stats .dashboard-stat.s-expired::before{background:#f59e0b}
.dashboard-home .dashboard-compact-stats .dashboard-stat.s-deleted::before{background:#f87171}
.dashboard-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.dashboard-hero-btn{
  min-height:40px;
  border-radius:12px;
  border-color:rgba(255,255,255,.25);
  background:rgba(255,255,255,.11);
  color:#fff!important;
}
.dashboard-hero-btn:hover{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.36);
  color:#fff!important;
}
.dashboard-hero-btn.primary{
  background:#dcfce7;
  border-color:#dcfce7;
  color:#14532d!important;
}
.dashboard-hero-btn.primary:hover{
  background:#bbf7d0;
  border-color:#bbf7d0;
  color:#14532d!important;
}
.dashboard-home .dashboard-hero-side{
  padding:26px 30px;
  border-left:1px solid rgba(255,255,255,.12);
}
.dashboard-home .dashboard-side-card{
  position:relative;
  overflow:hidden;
  padding:22px;
  border-radius:20px;
  background:rgba(255,255,255,.1);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12),0 18px 40px rgba(0,0,0,.12);
}
.dashboard-home .dashboard-side-card::after{
  content:'';
  position:absolute;
  right:-38px;
  bottom:-42px;
  width:120px;
  height:120px;
  border-radius:999px;
  background:rgba(220,252,231,.12);
}
.dashboard-home .dashboard-side-big{
  position:relative;
  z-index:1;
  font-size:28px;
  line-height:1.15;
  overflow-wrap:anywhere;
}
.dashboard-home .dashboard-side-label,
.dashboard-home .dashboard-side-copy{
  position:relative;
  z-index:1;
}
.dashboard-side-link{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:14px;
  min-height:34px;
  padding:7px 12px;
  border-radius:999px;
  background:#dcfce7;
  color:#14532d!important;
  font-size:13px;
  font-weight:900;
  text-decoration:none!important;
}
.dashboard-status-card{
  overflow:hidden;
}
.dashboard-home .dashboard-stats{
  gap:0;
  background:#fff;
}
.dashboard-home .dashboard-stat{
  position:relative;
  padding:26px 20px 24px;
  border-right:1px solid #e2e8f0;
  border-top:0;
  overflow:hidden;
}
.dashboard-home .dashboard-stat::before{
  content:'';
  position:absolute;
  left:20px;
  top:18px;
  width:34px;
  height:4px;
  border-radius:999px;
  background:#22c55e;
}
.dashboard-home .dashboard-stat.s-expiring::before{background:#3b82f6}
.dashboard-home .dashboard-stat.s-expired::before{background:#f59e0b}
.dashboard-home .dashboard-stat.s-deleted::before{background:#ef4444}
.dashboard-home .dashboard-stat:hover{
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  transform:translateY(-1px);
}
.dashboard-home .dashboard-stat-num{
  margin-top:12px;
  font-size:42px;
}
.dashboard-home .dashboard-main-grid .box_c{
  overflow:hidden;
}
.dashboard-home .dashboard-main-grid{
  grid-template-columns:minmax(0,1fr);
  gap:16px;
  align-items:start;
}
.dashboard-home .dashboard-card-head{
  min-height:auto;
  padding:18px 22px;
  background:
    radial-gradient(circle at top left,rgba(34,197,94,.1),transparent 30%),
    linear-gradient(180deg,#fff 0%,#f8fafc 100%);
}
.dashboard-home .dashboard-card-head h2{
  font-size:19px;
}
.dashboard-card-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:7px 12px;
  border:1px solid #d7e3ef;
  border-radius:999px;
  background:#fff;
  color:#14532d!important;
  font-size:13px;
  font-weight:900;
}
.dashboard-home .dashboard-attention-list{
  gap:10px;
  padding:14px 16px 16px;
  background:#f8fafc;
}
.dashboard-home .dashboard-attention-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border:1px solid #dbe7f0;
  border-radius:8px;
  background:#fff;
  box-shadow:0 8px 20px rgba(15,23,42,.04);
}
.dashboard-home .dashboard-attention-item:first-child{
  border-top:1px solid #dbe7f0;
}
.dashboard-home .dashboard-attention-item:hover{
  background:#fff;
  border-color:#b7d7c4;
}
.dashboard-home .dashboard-domain-name{
  color:#052e16;
  font-size:16px;
}
.dashboard-home .dashboard-domain-meta{
  color:#64748b;
  font-weight:700;
}
.dashboard-home .dashboard-domain-next{
  margin-top:4px;
  color:#0f172a;
  font-size:14px;
  font-weight:900;
}
.dashboard-home .dashboard-domain-copy{
  margin-top:6px;
  max-width:760px;
  color:#475569;
  font-size:13px;
  font-weight:700;
  line-height:1.45;
}
.dashboard-home .dashboard-badge{
  min-height:30px;
  min-width:82px;
  font-weight:900;
}
.dashboard-badge.info{background:#dbeafe;color:#1e40af}
.dashboard-badge.stable{background:#dcfce7;color:#166534}
.dashboard-home .dashboard-attention-item.urgent{border-color:#fecaca;box-shadow:inset 4px 0 0 #dc2626,0 8px 20px rgba(15,23,42,.04)}
.dashboard-home .dashboard-attention-item.warning{border-color:#fde68a;box-shadow:inset 4px 0 0 #d97706,0 8px 20px rgba(15,23,42,.04)}
.dashboard-home .dashboard-attention-item.info{border-color:#bfdbfe;box-shadow:inset 4px 0 0 #2563eb,0 8px 20px rgba(15,23,42,.04)}
.dashboard-home .dashboard-attention-item .gh_button{
  margin:0!important;
  border-radius:12px;
}
.dashboard-home .dashboard-empty{
  margin:14px 16px 16px;
  border:1px solid #bbf7d0;
  border-radius:14px;
  background:#f0fdf4;
  color:#166534;
  font-weight:800;
}
.dashboard-action-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  padding:16px;
}
.dashboard-action-card{
  min-height:116px;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:16px;
  border:1px solid #d7e3ef;
  border-radius:8px;
  background:#fff;
  text-decoration:none!important;
  box-shadow:0 8px 20px rgba(15,23,42,.04);
  transition:transform var(--t),border-color var(--t),box-shadow var(--t);
}
.dashboard-action-card:hover{
  transform:translateY(-1px);
  border-color:#9bd3ad;
  box-shadow:0 12px 26px rgba(15,23,42,.08);
}
.dashboard-action-mark{
  width:36px;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:#e7f8ee;
  color:#14532d;
  font-family:var(--display);
  font-weight:900;
}
.dashboard-action-mark svg{
  width:20px;
  height:20px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.dashboard-action-body{
  display:grid;
  gap:6px;
}
.dashboard-action-body strong{
  color:#052e16;
  font-family:var(--display);
  font-size:16px;
  line-height:1.2;
}
.dashboard-action-body em{
  color:#64748b;
  font-size:13px;
  font-style:normal;
  font-weight:700;
  line-height:1.45;
}
@media(max-width:900px){
  .dashboard-home .dashboard-compact-stats{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .dashboard-home .dashboard-main-grid{
    grid-template-columns:1fr;
  }
  .dashboard-home .dashboard-stats{
    grid-template-columns:repeat(2,1fr);
  }
  .dashboard-home .dashboard-stat:nth-child(2){
    border-right:none;
  }
  .dashboard-home .dashboard-attention-item{
    grid-template-columns:minmax(0,1fr) auto;
  }
  .dashboard-home .dashboard-attention-item .gh_button{
    grid-column:1 / -1;
    justify-content:center;
  }
  .dashboard-action-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:700px){
  .dashboard-home .dashboard-hero-main,
  .dashboard-home .dashboard-hero-side{
    padding:22px 18px;
  }
  .dashboard-home .dashboard-hero-title{
    font-size:26px;
  }
  .dashboard-home .dashboard-compact-stats{
    grid-template-columns:1fr 1fr;
  }
  .dashboard-hero-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .dashboard-home .dashboard-stats{
    grid-template-columns:1fr;
  }
  .dashboard-home .dashboard-stat{
    border-right:none;
    border-bottom:1px solid #e2e8f0;
    text-align:left;
  }
  .dashboard-home .dashboard-stat:last-child{
    border-bottom:none;
  }
  .dashboard-home .dashboard-card-head{
    display:block;
  }
  .dashboard-card-link{
    margin-top:12px;
  }
  .dashboard-home .dashboard-attention-list{
    padding:14px;
  }
  .dashboard-home .dashboard-attention-item{
    grid-template-columns:1fr;
  }
  .dashboard-home .dashboard-badge{
    width:max-content;
  }
  .dashboard-action-grid{
    grid-template-columns:1fr;
    padding:14px;
  }
  .dashboard-action-card{
    min-height:auto;
  }
}

/* index.php: public landing polish */
.dashboard-landing-hero{
  background:
    radial-gradient(circle at 18% 20%,rgba(34,197,94,.22),transparent 28%),
    radial-gradient(circle at 86% 22%,rgba(14,165,233,.16),transparent 28%),
    linear-gradient(135deg,#0f4b16 0%,#14532d 52%,#12395a 100%)!important;
}
.dashboard-landing-icon{
  width:62px;
  height:62px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 16px;
  border-radius:20px;
  background:rgba(220,252,231,.14);
  color:#dcfce7;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.16),0 20px 36px rgba(0,0,0,.16);
}
.dashboard-landing-icon svg{
  width:31px;
  height:31px;
}
.dashboard-landing-title{letter-spacing:0}
.dashboard-landing-grid{
  background:#f8fafc;
}
.dashboard-landing-feature{
  background:#fff;
  padding:24px 26px 22px;
  transition:background var(--t),transform var(--t);
}
.dashboard-landing-feature:hover{
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  transform:translateY(-1px);
}
.dashboard-landing-feature-icon{
  width:38px;
  height:38px;
  border-radius:14px;
  margin-bottom:12px;
  background:#e7f8ee;
  color:#166534;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}
.dashboard-landing-feature-title{
  font-size:14px;
}
.dashboard-landing-feature-copy{
  max-width:230px;
}
.dashboard-landing-feature-icon::before,
.dashboard-landing-feature-icon::after{
  content:'';
  position:absolute;
  background:currentColor;
}
.dashboard-landing-feature-icon.ns::before{
  width:8px;
  height:8px;
  left:15px;
  top:6px;
  border-radius:999px;
  background:currentColor;
  box-shadow:-10px 18px 0 currentColor,10px 18px 0 currentColor;
}
.dashboard-landing-feature-icon.ns::after{
  left:8px;
  top:14px;
  width:22px;
  height:16px;
  background:
    linear-gradient(36deg,transparent 46%,currentColor 47%,currentColor 53%,transparent 54%),
    linear-gradient(-36deg,transparent 46%,currentColor 47%,currentColor 53%,transparent 54%),
    linear-gradient(90deg,transparent 46%,currentColor 47%,currentColor 53%,transparent 54%);
  opacity:.95;
}
.dashboard-landing-feature-icon.contact::before{
  width:12px;
  height:12px;
  left:13px;
  top:9px;
  border-radius:999px;
}
.dashboard-landing-feature-icon.contact::after{
  width:22px;
  height:10px;
  left:8px;
  bottom:9px;
  border-radius:999px 999px 5px 5px;
}
.dashboard-landing-feature-icon.security::before{
  left:10px;
  top:18px;
  width:18px;
  height:14px;
  border-radius:4px;
}
.dashboard-landing-feature-icon.security::after{
  left:13px;
  top:9px;
  width:12px;
  height:13px;
  border:2px solid currentColor;
  border-bottom:0;
  border-radius:999px 999px 0 0;
  background:transparent;
}
.dashboard-landing-feature-icon.history::before{
  left:10px;
  top:9px;
  width:18px;
  height:24px;
  border-radius:4px;
  background:transparent;
  border:2px solid currentColor;
}
.dashboard-landing-feature-icon.history::after{
  left:15px;
  top:16px;
  width:10px;
  height:2px;
  box-shadow:0 5px 0 currentColor,0 10px 0 currentColor;
}
.dashboard-landing-footer{
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)!important;
}
.dashboard-landing-actions{
  display:flex;
  align-items:center;
  justify-content:center;
}
.dashboard-landing-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:13px 28px;
  border-radius:16px;
  font-family:var(--display);
  font-size:16px;
  font-weight:900;
  text-decoration:none;
  transition:transform var(--t),box-shadow var(--t),background var(--t),border-color var(--t);
}
.dashboard-landing-cta.primary{
  background:#fff;
  color:#0f3f22;
  box-shadow:0 18px 38px rgba(0,0,0,.24);
}
.dashboard-landing-cta.primary:hover{
  transform:translateY(-2px);
  color:#0f3f22;
  box-shadow:0 24px 46px rgba(0,0,0,.28);
}
.dashboard-landing-footer{
  display:grid!important;
  grid-template-columns:1fr;
  gap:18px;
  padding:26px!important;
}
.landing-path{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:15px;
  padding:18px;
  border:1px solid #dbe7f0;
  border-radius:20px;
  background:#fff;
  box-shadow:0 14px 34px rgba(15,23,42,.06);
}
.landing-path.new-client{
  border-color:#bbf7d0;
  background:
    radial-gradient(circle at 94% 8%,rgba(34,197,94,.12),transparent 30%),
    linear-gradient(135deg,#f8fffb 0%,#fff 100%);
}
.landing-order-panel{
  grid-template-columns:auto minmax(0,1fr) auto;
  min-height:128px;
  padding:24px 28px;
  border-radius:24px;
  overflow:hidden;
  position:relative;
}
.landing-order-panel::before{
  content:'';
  position:absolute;
  inset:auto 18% -80px auto;
  width:240px;
  height:240px;
  border-radius:999px;
  background:rgba(34,197,94,.1);
  pointer-events:none;
}
.landing-path.existing-client{
  background:
    radial-gradient(circle at 92% 10%,rgba(59,130,246,.1),transparent 28%),
    linear-gradient(135deg,#fff 0%,#f8fbff 100%);
}
.landing-order-icon{
  width:58px;
  height:58px;
  border-radius:20px;
}
.landing-order-icon svg{
  width:28px;
  height:28px;
}
.landing-order-copy{
  position:relative;
  z-index:1;
}
.landing-path-icon{
  width:46px;
  height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  background:#eef6ff;
  color:#12395a;
}
.landing-path.new-client .landing-path-icon{
  background:#dcfce7;
  color:#166534;
}
.landing-path-icon svg{
  width:23px;
  height:23px;
}
.landing-path strong{
  display:block;
  margin-bottom:4px;
  color:#052e16;
  font-family:var(--display);
  font-size:16px;
  font-weight:900;
}
.landing-path span{
  display:block;
  color:#475569;
  font-size:14px;
  line-height:1.45;
}
.landing-order-points{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:13px;
}
.landing-order-points em{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:#ecfdf5;
  color:#166534;
  font-size:12px;
  font-style:normal;
  font-weight:900;
}
.landing-order-points em::before{
  content:'';
  width:6px;
  height:6px;
  border-radius:999px;
  background:#22c55e;
}
.landing-path-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 16px;
  border-radius:14px;
  font-family:var(--display);
  font-size:14px;
  font-weight:900;
  white-space:nowrap;
  text-decoration:none;
}
.landing-path-btn.login{
  background:#f1f5f9;
  color:#12395a;
  border:1px solid #dbe7f0;
}
.landing-path-btn.order{
  position:relative;
  z-index:1;
  background:#14532d;
  color:#fff;
  box-shadow:0 14px 28px rgba(20,83,45,.18);
}
.landing-path-btn:hover{
  transform:translateY(-1px);
  text-decoration:none;
}
.landing-path-btn.order:hover{
  background:#0f3f22;
  color:#fff;
}
@media(max-width:860px){
  .dashboard-landing-grid{
    display:grid!important;
    grid-template-columns:1fr 1fr;
  }
  .dashboard-landing-feature{
    border-right:none;
    border-bottom:1px solid var(--border);
  }
  .dashboard-landing-feature:nth-child(odd){
    border-right:1px solid var(--border);
  }
  .dashboard-landing-feature:nth-last-child(-n+2){
    border-bottom:none;
  }
  .dashboard-landing-footer{
    grid-template-columns:1fr;
  }
}
@media(max-width:560px){
  .dashboard-landing-hero{
    padding:42px 22px 36px;
  }
  .dashboard-landing-grid{
    grid-template-columns:1fr;
  }
  .dashboard-landing-feature,
  .dashboard-landing-feature:nth-child(odd),
  .dashboard-landing-feature:nth-last-child(-n+2){
    border-right:none;
    border-bottom:1px solid var(--border);
  }
  .dashboard-landing-feature:last-child{
    border-bottom:none;
  }
  .dashboard-landing-feature{
    display:grid;
    grid-template-columns:auto 1fr;
    column-gap:14px;
    padding:18px 20px;
  }
  .dashboard-landing-feature-icon{
    grid-row:1 / span 2;
    margin-bottom:0;
  }
  .dashboard-landing-feature-copy{
    max-width:none;
  }
  .dashboard-landing-actions{
    align-items:stretch;
  }
  .dashboard-landing-cta{
    width:100%;
  }
  .landing-path{
    grid-template-columns:auto minmax(0,1fr);
  }
  .landing-order-panel{
    padding:20px;
  }
  .landing-order-icon{
    width:48px;
    height:48px;
  }
  .landing-order-points{
    gap:7px;
  }
  .landing-path-btn{
    grid-column:1 / -1;
    width:100%;
  }
}

/* domains.php: modern domain command center */
.domains-console{
  overflow:hidden;
  border-color:#d7e3ef;
  box-shadow:0 20px 54px rgba(15,23,42,.08);
}
.domains-page-icon{
  background:#e7f8ee!important;
  color:#0f7a35!important;
}
.domains-console .domain-hero{
  border-bottom:0;
}
.domains-console .domain-hero-copy{
  max-width:560px;
}
.domains-console .domain-command-bar{
  display:grid;
  grid-template-columns:minmax(260px,1fr) 190px 210px auto;
  gap:12px;
  align-items:end;
  padding:18px 20px;
  background:
    radial-gradient(circle at left top,rgba(34,197,94,.12),transparent 28%),
    linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  border-bottom:1px solid #e2e8f0;
}
.domains-console .domain-search-bar{
  min-width:0;
  align-self:end;
  padding:0!important;
  border:0!important;
  background:transparent!important;
}
.domains-console #domainSearch{
  min-height:46px;
  height:46px;
  display:block;
  margin:0!important;
  border-radius:14px;
  border:1.5px solid #d5e1ec;
  background-color:#fff;
  background-position:14px center;
  padding:0 14px 0 42px;
  box-shadow:0 8px 18px rgba(15,23,42,.04);
}
.domains-console #domainSearch:focus{
  border-color:#16a34a;
  box-shadow:0 0 0 4px rgba(22,163,74,.12);
}
.domains-console .domain-status-filter{
  margin:0;
}
.domains-console .domain-status-filter span{
  display:block;
  margin:0 0 7px;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  letter-spacing:.09em;
  text-transform:uppercase;
}
.domains-console .domain-status-filter select{
  min-height:46px;
  border-radius:14px;
  border:1.5px solid #d5e1ec;
  background-color:#fff;
  font-size:14px;
  font-weight:700;
  box-shadow:0 8px 18px rgba(15,23,42,.04);
}
.domains-console .domain-report-btn{
  min-height:46px;
  justify-content:center;
  border-radius:14px;
  background:#14532d;
  border-color:#14532d;
  color:#fff!important;
  box-shadow:0 12px 22px rgba(20,83,45,.16);
}
.domains-console .domain-report-btn:hover{
  background:#0f3f22;
  border-color:#0f3f22;
  color:#fff!important;
}
.domains-console .box_c_content{
  padding:22px 20px 8px;
  background:#f8fafc;
}
.domains-console #dt2,
.domains-console #dt2 tbody{
  display:block!important;
  width:100%!important;
  border-collapse:separate!important;
}
.domains-console #dt2 thead{
  display:none!important;
}
.domains-console #dt2 tbody{
  display:grid!important;
  gap:14px!important;
}
.domains-console #dt2 tbody tr{
  display:grid!important;
  grid-template-columns:minmax(230px,1.25fr) minmax(130px,.6fr) minmax(130px,.6fr) minmax(170px,.75fr) auto!important;
  gap:14px!important;
  align-items:center!important;
  padding:16px!important;
  border:1px solid #dbe7f0!important;
  border-radius:18px!important;
  background:#fff!important;
  box-shadow:0 14px 32px rgba(15,23,42,.06)!important;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t)!important;
}
.domains-console #dt2 tbody tr:hover{
  transform:translateY(-1px);
  border-color:#b7d7c4!important;
  box-shadow:0 18px 42px rgba(15,23,42,.09)!important;
}
.domains-console #dt2 tbody tr.dom-hidden{
  display:none!important;
}
.domains-console #dt2 tbody tr.dom-page-hidden{
  display:none!important;
}
.domains-console #dt2 tbody td{
  display:block!important;
  width:auto!important;
  padding:0!important;
  border:0!important;
  background:transparent!important;
  text-align:left!important;
  vertical-align:middle!important;
}
.domains-console #dt2 tbody td:first-child{
  display:none!important;
}
.domains-console .dom-name{
  min-width:0;
}
.domains-console .dom-name-wrap{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
  margin-bottom:9px;
}
.domains-console .dom-name-text{
  min-width:0;
  color:#052e16;
  font-family:var(--display);
  font-size:18px;
  font-weight:800;
  line-height:1.15;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.domains-console .copy-domain-btn{
  width:28px;
  height:28px;
  flex:0 0 auto;
  border:1px solid #dbe7f0;
  border-radius:9px;
  background:#f8fafc;
  cursor:pointer;
  position:relative;
  transition:background var(--t),border-color var(--t),box-shadow var(--t);
}
.domains-console .copy-domain-btn::before{
  content:'';
  position:absolute;
  inset:7px;
  border:1.7px solid #64748b;
  border-radius:3px;
  box-shadow:3px -3px 0 -1px #f8fafc,3px -3px 0 0 #64748b;
}
.domains-console .copy-domain-btn:hover,
.domains-console .copy-domain-btn.copied{
  background:#dcfce7;
  border-color:#86efac;
}
.domains-console .dom-card-status{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:5px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.domains-console .dom-card-status.active{background:#dcfce7;color:#166534}
.domains-console .dom-card-status.expiring{background:#fef3c7;color:#92400e}
.domains-console .dom-card-status.expired{background:#fee2e2;color:#991b1b}
.domains-console .dom-card-status.deleted{background:#e2e8f0;color:#334155}
.domains-console .dom-card-status.nodate{background:#f1f5f9;color:#64748b}
.domains-console .dom-next-action{
  margin-top:10px;
  max-width:360px;
  padding:10px 12px;
  border:1px solid #dbe7f0;
  border-radius:8px;
  background:#f8fbff;
  box-shadow:inset 4px 0 0 #2563eb;
}
.domains-console .dom-next-action span,
.domains-console .dom-next-action strong,
.domains-console .dom-next-action em{
  display:block;
}
.domains-console .dom-next-action span{
  color:#64748b;
  font-size:10px;
  font-weight:900;
  letter-spacing:.09em;
  line-height:1.2;
  text-transform:uppercase;
}
.domains-console .dom-next-action strong{
  margin-top:4px;
  color:#0f172a;
  font-family:var(--display);
  font-size:13px;
  font-weight:900;
  line-height:1.2;
}
.domains-console .dom-next-action em{
  margin-top:3px;
  color:#475569;
  font-size:12px;
  font-style:normal;
  font-weight:700;
  line-height:1.35;
}
.domains-console .dom-next-action.active{
  border-color:#bbf7d0;
  background:#f0fdf4;
  box-shadow:inset 4px 0 0 #16a34a;
}
.domains-console .dom-next-action.expiring{
  border-color:#fde68a;
  background:#fffbeb;
  box-shadow:inset 4px 0 0 #d97706;
}
.domains-console .dom-next-action.expired{
  border-color:#fecaca;
  background:#fff7f7;
  box-shadow:inset 4px 0 0 #dc2626;
}
.domains-console .dom-next-action.deleted{
  border-color:#cbd5e1;
  background:#f8fafc;
  box-shadow:inset 4px 0 0 #64748b;
}
.domains-console .dom-renewal-chip{
  display:inline-grid;
  gap:2px;
  max-width:360px;
  margin-top:8px;
  padding:8px 10px;
  border:1px solid #bfdbfe;
  border-radius:8px;
  background:#eff6ff;
  box-shadow:inset 4px 0 0 #2563eb;
}
.domains-console .dom-renewal-chip span,
.domains-console .dom-renewal-chip strong{
  display:block;
  line-height:1.2;
}
.domains-console .dom-renewal-chip span{
  color:#64748b;
  font-size:10px;
  font-weight:900;
  letter-spacing:.09em;
  text-transform:uppercase;
}
.domains-console .dom-renewal-chip strong{
  color:#0f172a;
  font-family:var(--display);
  font-size:12px;
  font-weight:900;
  overflow-wrap:anywhere;
}
.domains-console .dom-renewal-chip.stable{border-color:#bbf7d0;background:#f0fdf4;box-shadow:inset 4px 0 0 #16a34a}
.domains-console .dom-renewal-chip.warning{border-color:#fde68a;background:#fffbeb;box-shadow:inset 4px 0 0 #d97706}
.domains-console .dom-renewal-chip.urgent{border-color:#fecaca;background:#fff7f7;box-shadow:inset 4px 0 0 #dc2626}
.domains-console .dom-renewal-chip.info{border-color:#bfdbfe;background:#eff6ff;box-shadow:inset 4px 0 0 #2563eb}
.domains-console .dom-cell-label{
  display:block;
  margin-bottom:5px;
  color:#94a3b8;
  font-size:10px;
  font-weight:900;
  letter-spacing:.1em;
  line-height:1.2;
  text-transform:uppercase;
}
.domains-console .dom-contact strong,
.domains-console .dom-ns strong{
  display:block;
  color:#0f172a;
  font-family:var(--display);
  font-size:14px;
  font-weight:800;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.domains-console .dom-valen{
  display:grid!important;
  gap:5px;
}
.domains-console .dom-valen .dom-status{
  width:max-content;
  max-width:100%;
  padding:5px 10px;
  border-radius:999px;
  font-size:13px;
  font-weight:900;
}
.domains-console .dom-expiry-hint{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:700;
  line-height:1.25;
}
.domains-console .dom-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  justify-content:flex-end!important;
}
.domains-console #dt2 tbody td.dom-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  align-items:center!important;
  justify-content:flex-end!important;
  white-space:normal!important;
}
.domains-console #dt2 tbody td.dom-contact::before,
.domains-console #dt2 tbody td.dom-ns::before,
.domains-console #dt2 tbody td.dom-valen::before,
.domains-console #dt2 tbody td.dom-badge::before{
  content:none!important;
  display:none!important;
}
.domains-console .dom-actions .gh_button{
  margin:0!important;
  min-height:38px;
  border-radius:12px;
  padding:8px 12px;
}
.domains-console .action-details{
  background:#14532d;
  border-color:#14532d;
  color:#fff!important;
}
.domains-console .action-details:hover{
  background:#0f3f22;
  border-color:#0f3f22;
  color:#fff!important;
}
.domains-console .gh_button.ui-icon.action-details::before{
  content:'';
  width:15px;
  height:15px;
  display:inline-block;
  background:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20h9'/%3E%3Cpath d='M16.5 3.5a2.1 2.1 0 0 1 3 3L7 19l-4 1 1-4Z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20h9'/%3E%3Cpath d='M16.5 3.5a2.1 2.1 0 0 1 3 3L7 19l-4 1 1-4Z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.domains-console .gh_button.ui-icon.action-epp::before{
  content:'';
  width:15px;
  height:15px;
  display:inline-block;
  background:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.3' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='7.5' cy='14.5' r='4.5'/%3E%3Cpath d='M11 11l9-9'/%3E%3Cpath d='M15.5 5.5l3 3'/%3E%3Cpath d='M18 3l3 3'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.3' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='7.5' cy='14.5' r='4.5'/%3E%3Cpath d='M11 11l9-9'/%3E%3Cpath d='M15.5 5.5l3 3'/%3E%3Cpath d='M18 3l3 3'/%3E%3C/svg%3E") center/contain no-repeat;
}
.domains-console .domain-table-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 20px 8px;
  background:#f8fafc;
  border-top:1px solid #e2e8f0;
}
.domains-console #domainCount{
  color:#64748b;
  font-size:13px;
  font-weight:800;
}
.domains-console .domain-per-page{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.domains-console .domain-per-page select{
  min-width:82px;
  border-radius:11px;
  font-size:13px;
  font-weight:800;
}
.domains-console .domain-pagination{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  justify-content:center;
  padding:12px 20px 22px;
  background:#f8fafc;
}
.domains-console .domain-page-btn{
  min-width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #d7e3ef;
  border-radius:11px;
  background:#fff;
  color:#334155;
  font-weight:900;
}
.domains-console .domain-page-btn.active{
  background:#14532d;
  border-color:#14532d;
  color:#fff;
}
.domains-console .domain-page-btn.disabled{
  opacity:.45;
  pointer-events:none;
}
.domains-console .domain-search-none{
  margin:14px 20px 0;
  border:1px solid #dbe7f0;
  border-radius:14px;
  background:#fff;
}
.domains-console .domain-filter-banner{
  margin:18px 20px 0;
  border-radius:14px;
}
@media(max-width:980px){
  .domains-console .domain-command-bar{
    grid-template-columns:1fr 1fr;
  }
  .domains-console .domain-report-btn{
    grid-column:1 / -1;
  }
  .domains-console #dt2 tbody tr{
    grid-template-columns:minmax(0,1fr) minmax(130px,.6fr) minmax(130px,.6fr);
  }
  .domains-console .dom-valen,
  .domains-console .dom-actions{
    grid-column:auto;
  }
}
@media(max-width:700px){
  .domains-console .domain-command-bar{
    grid-template-columns:1fr;
    padding:16px;
  }
  .domains-console .box_c_content{
    padding:16px;
  }
  .domains-console #dt2 tbody tr{
    grid-template-columns:1fr!important;
    gap:12px!important;
    padding:15px!important;
  }
  .domains-console .dom-name-text{
    white-space:normal;
  }
  .domains-console .dom-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    justify-content:stretch!important;
    gap:0!important;
    row-gap:0!important;
    padding-top:14px!important;
    border-top:1px solid #e2e8f0!important;
    margin-top:2px!important;
  }
  .domains-console .dom-actions .gh_button{
    display:flex!important;
    width:100%!important;
    margin:0!important;
    justify-content:center;
    min-height:42px;
  }
  .domains-console .dom-actions .gh_button + .gh_button{
    margin-top:12px!important;
  }
  .domains-console #dt2 tbody td.dom-actions{
    display:flex!important;
    flex-direction:column!important;
    gap:12px!important;
  }
  .domains-console #dt2 tbody td.dom-actions a.gh_button{
    width:100%!important;
    margin:0!important;
    justify-content:center!important;
  }
  .domains-console #dt2 tbody td.dom-actions a.gh_button + a.gh_button{
    margin-top:12px!important;
  }
  .domains-console #dt2 tbody td.dom-contact::before,
  .domains-console #dt2 tbody td.dom-ns::before,
  .domains-console #dt2 tbody td.dom-valen::before,
  .domains-console #dt2 tbody td.dom-badge::before{
    content:none!important;
    display:none!important;
  }
  .domains-console .domain-table-footer{
    flex-direction:column;
    align-items:stretch;
  }
  .domains-console .domain-per-page{
    justify-content:space-between;
  }
}

/* --- Final frontend sweep: auth flow + tools polish ------------------------ */
body.auth-screen,
body:has(.login_form){
  min-height:100dvh;
  overflow-y:auto;
  background:
    radial-gradient(circle at 16% 18%,rgba(34,197,94,.18),transparent 28%),
    radial-gradient(circle at 86% 78%,rgba(14,165,233,.16),transparent 30%),
    linear-gradient(135deg,#092d13 0%,#0f4b16 46%,#12395a 100%)!important;
}
body.auth-screen::before,
body:has(.login_form)::before{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(135deg,rgba(255,255,255,.035) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.035) 50%,rgba(255,255,255,.035) 75%,transparent 75%,transparent);
  background-size:44px 44px;
  opacity:.36;
}
body.auth-screen > .container:not(#footer),
body:has(.login_form) > .container:not(#footer){
  position:relative;
  z-index:1;
}
body.auth-screen > .container:not(#footer)::before,
body:has(.login_form) > .container:not(#footer)::before{
  margin-bottom:18px;
  color:#fff;
  text-shadow:0 10px 30px rgba(0,0,0,.22);
}
body.auth-screen .box_c,
body:has(.login_form) .box_c{
  border:1px solid rgba(255,255,255,.18);
  border-radius:26px;
  box-shadow:0 32px 90px rgba(2,6,23,.36);
  backdrop-filter:blur(10px);
}
body.auth-screen .box_c_heading,
body:has(.login_form) .box_c_heading{
  padding:18px 22px;
  background:linear-gradient(135deg,#f8fffb 0%,#eefaf4 100%);
  border-bottom:1px solid #dbe9e1;
}
body.auth-screen .box_c_heading p,
body:has(.login_form) .box_c_heading p{
  color:#083b17!important;
  font-weight:800;
}
body.auth-screen .box_c_heading .box_c_ico,
body:has(.login_form) .box_c_heading .box_c_ico{
  background:#e3f9ea;
  border:1px solid #c7f1d3;
}
body.auth-screen .box_c_heading .box_c_ico img,
body:has(.login_form) .box_c_heading .box_c_ico img{
  filter:none;
}
body.auth-screen .box_c_content,
body:has(.login_form) .box_c_content{
  padding:30px;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
body.auth-screen .login_form label,
body:has(.login_form) .login_form label{
  color:#536884;
  font-size:11px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}
body.auth-screen input[type=text],
body.auth-screen input[type=password],
body.auth-screen input[type=email],
body:has(.login_form) input[type=text],
body:has(.login_form) input[type=password],
body:has(.login_form) input[type=email]{
  min-height:46px;
  border:1.5px solid #d5e3ef;
  border-radius:14px;
  background:#fff;
  color:#0f172a;
  box-shadow:inset 0 1px 0 rgba(15,23,42,.03);
}
body.auth-screen input[type=text]:focus,
body.auth-screen input[type=password]:focus,
body.auth-screen input[type=email]:focus,
body:has(.login_form) input[type=text]:focus,
body:has(.login_form) input[type=password]:focus,
body:has(.login_form) input[type=email]:focus{
  border-color:#22c55e;
  box-shadow:0 0 0 4px rgba(34,197,94,.13);
}
body.auth-screen input[type=submit],
body:has(.login_form) input[type=submit]{
  min-height:46px;
  border-radius:14px;
  background:#14532d;
  box-shadow:0 14px 30px rgba(20,83,45,.22);
}
body.auth-screen input[type=submit]:hover,
body:has(.login_form) input[type=submit]:hover{
  background:#0f3f22;
  box-shadow:0 18px 34px rgba(20,83,45,.28);
}
.auth-flow-copy{
  padding:22px;
  border:1px solid #dbe9e1;
  border-radius:20px;
  background:
    radial-gradient(circle at 88% 10%,rgba(34,197,94,.18),transparent 30%),
    linear-gradient(135deg,#f7fffb 0%,#eef8f4 100%);
}
.auth-flow-copy h2{
  color:#083b17;
  font-size:26px;
}
.totp-panel{
  border-color:#dbe9e1;
  border-radius:22px;
  background:
    radial-gradient(circle at 90% 14%,rgba(34,197,94,.18),transparent 26%),
    linear-gradient(135deg,#f7fffb 0%,#eef8f4 100%);
}
.totp-icon{
  background:#14532d!important;
  box-shadow:0 16px 34px rgba(20,83,45,.24);
}
.auth-card .box_c_heading{
  gap:12px;
}
.auth-heading-icon,
.epp-heading-icon{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:#e3f9ea;
  color:#14532d;
  border:1px solid #c7f1d3;
  flex-shrink:0;
}
.auth-heading-icon svg,
.epp-heading-icon svg{
  width:19px;
  height:19px;
  display:block;
}
.auth-card-login .auth-heading-icon{
  background:#dcfce7;
  color:#166534;
}
.auth-card-reset-request .auth-heading-icon{
  background:#e0f2fe;
  border-color:#bae6fd;
  color:#0369a1;
}
.auth-card-new-password .auth-heading-icon{
  background:#fef3c7;
  border-color:#fde68a;
  color:#92400e;
}
.auth-card-2fa .auth-heading-icon{
  background:#dcfce7;
  border-color:#86efac;
  color:#166534;
}
.auth-card .auth-alert{
  border-radius:16px;
  margin-bottom:18px;
}
.auth-card .auth-center-note,
.auth-card .totp-back{
  margin-top:18px;
  text-align:center;
}
.auth-card .auth-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 12px;
  border-radius:999px;
  color:#14532d;
  font-weight:800;
}
.auth-card .auth-link:hover{
  background:#dcfce7;
  color:#0f3f22;
  text-decoration:none;
}
.auth-card-new-password .profile-input-note{
  margin:2px 0 16px;
  padding:14px 16px;
  border:1px solid #dbe7f0;
  border-radius:16px;
  background:#f8fbff;
}
.auth-card-2fa .totp-code-input{
  max-width:260px;
  margin-left:auto;
  margin-right:auto;
  font-size:24px!important;
  letter-spacing:.42em;
  text-align:center;
}
.auth-card-2fa .totp-submit{
  max-width:260px;
  margin-left:auto;
  margin-right:auto;
}

.epp-flow .box_c_heading{
  gap:12px;
}
.epp-flow .domain-hero-title{
  overflow-wrap:anywhere;
}
.epp-action-shell{
  background:
    radial-gradient(circle at 90% 4%,rgba(34,197,94,.13),transparent 28%),
    linear-gradient(180deg,#f8fbff 0%,#fff 100%);
}
.epp-flow .action-confirm-card{
  border-radius:24px;
  background:
    radial-gradient(circle at 94% 8%,rgba(245,158,11,.14),transparent 30%),
    linear-gradient(135deg,#fffaf0 0%,#f8fffb 100%);
}
.epp-flow .action-confirm-icon{
  border-radius:18px;
}
.epp-flow .epp-destination-card{
  border-radius:18px;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}
.epp-flow .epp-sensitive-note{
  border-radius:18px;
  background:
    radial-gradient(circle at 96% 10%,rgba(245,158,11,.12),transparent 26%),
    linear-gradient(135deg,#fff7ed 0%,#fffdf6 100%);
}
.epp-flow .epp-confirm-check{
  border-radius:16px;
  box-shadow:0 12px 28px rgba(15,23,42,.05);
}
.epp-flow .action-result{
  max-width:720px;
  margin:0 auto;
  padding:34px 28px;
  border:1px solid #bbf7d0;
  border-radius:24px;
  background:
    radial-gradient(circle at 90% 10%,rgba(34,197,94,.16),transparent 30%),
    linear-gradient(135deg,#f8fffb 0%,#fff 100%);
  box-shadow:0 20px 55px rgba(15,23,42,.08);
}
.epp-heading-icon{
  background:#eef6ff;
  border-color:#cfe3f7;
  color:#12395a;
}

.watchlist-section{
  padding:28px 32px 32px;
  background:linear-gradient(180deg,#f7fbff 0%,#eef9f2 100%);
}
.watchlist-card{
  border:1px solid #d7e7f0;
  border-radius:24px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 20px 60px rgba(15,23,42,.08);
}
.watchlist-card-head{
  padding:26px 28px;
  background:
    radial-gradient(circle at 88% 10%,rgba(34,197,94,.18),transparent 26%),
    linear-gradient(135deg,#f8fffb 0%,#eefaf4 100%);
}
.watchlist-card-head h2{
  color:#083b17;
  font-size:24px;
  letter-spacing:0;
}
.watchlist-card-head p{
  display:inline-flex;
  margin-top:10px;
  padding:6px 11px;
  border-radius:999px;
  background:#dcfce7;
  color:#166534;
  font-weight:800;
}
.watchlist-add-form{
  display:grid;
  grid-template-columns:minmax(180px,1.2fr) minmax(180px,1fr) auto;
  gap:12px;
  padding:22px 28px;
  background:#fff;
}
.watchlist-add-form input[type=text]{
  min-height:46px;
  border:1.5px solid #d5e3ef;
  border-radius:14px;
  background:#f8fbff;
  font-size:15px;
}
.watchlist-add-form input[type=text]:focus{
  background:#fff;
  border-color:#22c55e;
  box-shadow:0 0 0 4px rgba(34,197,94,.12);
}
.watchlist-add-btn{
  min-height:46px;
  border-radius:14px;
  background:#14532d;
  box-shadow:0 12px 26px rgba(20,83,45,.2);
}
.watchlist-add-btn:hover{
  background:#0f3f22;
  opacity:1;
}
.watchlist-msg{
  margin:18px 28px 0;
  border:1px solid transparent;
  border-radius:16px;
}
.watchlist-table{
  border-collapse:separate;
  border-spacing:0 12px;
  padding:14px 20px 20px;
}
.watchlist-table th{
  padding:0 14px 4px;
  background:transparent;
  border:0;
}
.watchlist-table td{
  padding:16px 14px;
  border-top:1px solid #dbe7f0;
  border-bottom:1px solid #dbe7f0;
  background:#fbfdff;
}
.watchlist-table td:first-child{
  border-left:1px solid #dbe7f0;
  border-radius:18px 0 0 18px;
}
.watchlist-table td:last-child{
  border-right:1px solid #dbe7f0;
  border-radius:0 18px 18px 0;
}
.watchlist-domain{
  color:#0f172a;
  font-size:16px;
  font-weight:900;
}
.watchlist-badge{
  padding:6px 11px;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
}
.watchlist-actions{
  justify-content:flex-end;
}
.watchlist-btn{
  min-height:34px;
  border-radius:11px;
  padding:7px 12px;
  background:#fff;
  font-weight:800;
}
.watchlist-btn.register{
  background:#14532d;
  border-color:#14532d;
  color:#fff;
}
.watchlist-btn.register:hover{
  background:#0f3f22;
  border-color:#0f3f22;
  color:#fff;
}
.watchlist-empty{
  margin:22px 28px 28px;
  border:1px dashed #bdd7c8;
  border-radius:18px;
  background:#f8fffb;
  color:#536884;
}
.timeline-empty{
  margin:22px;
  border:1px dashed #d5e3ef;
  border-radius:20px;
  background:#f8fbff;
}
.timeline-empty-emoji{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  background:#e8f7ee;
  color:transparent;
  font-size:0;
}
.timeline-empty-emoji::before{
  content:'';
  width:22px;
  height:22px;
  background:#14532d;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 6h13'/%3E%3Cpath d='M8 12h13'/%3E%3Cpath d='M8 18h13'/%3E%3Cpath d='M3 6h.01'/%3E%3Cpath d='M3 12h.01'/%3E%3Cpath d='M3 18h.01'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 6h13'/%3E%3Cpath d='M8 12h13'/%3E%3Cpath d='M8 18h13'/%3E%3Cpath d='M3 6h.01'/%3E%3Cpath d='M3 12h.01'/%3E%3Cpath d='M3 18h.01'/%3E%3C/svg%3E") center/contain no-repeat;
}

@media(max-width:760px){
  body.auth-screen,
  body:has(.login_form){
    min-height:100dvh;
    justify-content:flex-start;
    padding-top:max(18px,env(safe-area-inset-top));
    padding-bottom:18px;
  }
  body.auth-screen .container,
  body:has(.login_form) .container{
    padding:12px 14px!important;
  }
  body.auth-screen > .container:not(#footer)::before,
  body:has(.login_form) > .container:not(#footer)::before{
    margin-top:0!important;
    margin-bottom:12px!important;
  }
  body.auth-screen .box_c,
  body:has(.login_form) .box_c{
    border-radius:22px!important;
    box-shadow:0 22px 54px rgba(2,6,23,.28)!important;
  }
  body.auth-screen .box_c_content,
  body:has(.login_form) .box_c_content{
    padding:18px!important;
  }
  .watchlist-section{
    padding:18px 16px 22px;
  }
  .watchlist-card{
    border-radius:22px;
  }
  .watchlist-card-head,
  .watchlist-add-form{
    padding:20px;
  }
  .watchlist-add-form{
    grid-template-columns:1fr;
  }
  .watchlist-table,
  .watchlist-table tbody,
  .watchlist-table tr,
  .watchlist-table td{
    display:block;
    width:100%;
  }
  .watchlist-table{
    border-spacing:0;
    padding:14px;
  }
  .watchlist-table thead{
    display:none;
  }
  .watchlist-table tr{
    margin-bottom:14px;
    padding:16px;
    border:1px solid #dbe7f0;
    border-radius:18px;
    background:#fbfdff;
  }
  .watchlist-table td{
    padding:8px 0;
    border:0!important;
    border-radius:0!important;
    background:transparent;
  }
  .watchlist-table td::before{
    display:block;
    margin-bottom:4px;
    color:#94a3b8;
    font-size:10px;
    font-weight:900;
    letter-spacing:.1em;
    text-transform:uppercase;
  }
  .watchlist-table td::before{content:attr(data-label)}
  .watchlist-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    justify-content:stretch;
  }
  .watchlist-actions form,
  .watchlist-actions .watchlist-btn{
    width:100%;
  }
  .watchlist-btn{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:40px;
  }
}

@media(max-width:380px){
  body.auth-screen .box_c_content,
  body:has(.login_form) .box_c_content{
    padding:14px!important;
  }
  body.auth-screen .formRow,
  body:has(.login_form) .formRow{
    padding:0;
  }
  .auth-recaptcha-wrap{
    height:70px;
  }
  .auth-recaptcha-wrap > *{
    transform:scale(.88);
  }
}

@media(max-width:340px){
  .auth-recaptcha-wrap{
    height:64px;
  }
  .auth-recaptcha-wrap > *{
    transform:scale(.8);
  }
}

/* Shared page title icons */
.page-soft-icon,
.profile-icon,
.auth-heading-icon,
.epp-heading-icon,
.dashboard-page-icon,
.domains-page-icon,
.audit-page-icon,
.client-page-icon,
.edit-domain-page-icon,
.tools-page-icon,
.auth-card-login .auth-heading-icon,
.auth-card-reset-request .auth-heading-icon,
.auth-card-new-password .auth-heading-icon,
.auth-card-2fa .auth-heading-icon{
  background:#e8f5ee!important;
  color:#14532d!important;
  border:1px solid #cfe8d6!important;
  box-shadow:inset 0 0 0 1px rgba(45,138,45,.08)!important;
}

/* index.php guest landing refresh */
body.portal-guest{
  background:
    linear-gradient(180deg,#f7fbf8 0%,#eef5f1 100%);
}
body.portal-guest > .container:not(.head_s_a):not(#footer){
  max-width:1120px;
}
body.portal-guest > .container:not(.head_s_a):not(#footer) > .row{
  padding-top:24px;
  padding-bottom:18px;
}
body.portal-guest .landing-card{
  display:grid;
  grid-template-rows:minmax(0,1fr) auto auto;
  min-height:clamp(610px,calc(100vh - 138px),760px);
  margin-bottom:0;
  border-color:#d7e3df;
  border-radius:14px;
  box-shadow:0 24px 58px rgba(15,23,42,.1);
}
body.portal-guest .dashboard-landing-hero{
  display:flex;
  align-items:center;
  min-height:0;
  padding:34px 36px;
  text-align:left;
  background:
    linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,0) 42%),
    repeating-linear-gradient(-45deg,rgba(255,255,255,.055) 0,rgba(255,255,255,.055) 1px,transparent 1px,transparent 18px),
    linear-gradient(135deg,#083d1e 0%,#14532d 50%,#12395a 100%)!important;
}
body.portal-guest .dashboard-landing-hero::before{
  opacity:0;
}
body.portal-guest .dashboard-landing-inner{
  width:100%;
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(320px,380px);
  gap:34px;
  align-items:center;
}
.landing-hero-copy{
  min-width:0;
}
.landing-brand-lockup{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
  padding:7px 10px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(255,255,255,.1);
  color:#dcfce7;
  font-size:12px;
  font-weight:900;
}
.landing-brand-lockup img{
  width:auto;
  height:22px;
  padding:4px 7px;
  border-radius:999px;
  background:#fff;
}
body.portal-guest .dashboard-landing-title{
  max-width:620px;
  margin:0 0 10px;
  color:#fff;
  font-size:34px;
  line-height:1.08;
  letter-spacing:0;
}
body.portal-guest .dashboard-landing-copy{
  max-width:560px;
  margin:0;
  color:rgba(255,255,255,.82);
  font-size:16px;
}
.landing-login-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
  max-width:590px;
  margin-top:22px;
  padding:12px;
  border:1px solid rgba(255,255,255,.2);
  border-radius:18px;
  background:rgba(255,255,255,.1);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 18px 42px rgba(2,6,23,.12);
}
.landing-login-copy{
  min-width:0;
  padding-left:4px;
}
.landing-login-copy span,
.landing-login-copy strong{
  display:block;
}
.landing-login-copy span{
  margin-bottom:3px;
  color:#fff;
  font-family:var(--display);
  font-size:16px;
  font-weight:900;
}
.landing-login-copy strong{
  max-width:350px;
  color:rgba(255,255,255,.73);
  font-size:13px;
  font-weight:700;
  line-height:1.35;
}
.landing-login-panel .landing-login-cta{
  min-width:168px;
  min-height:54px;
  border-radius:14px;
  box-shadow:0 18px 36px rgba(2,6,23,.24);
}
.landing-login-panel .landing-login-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 44px rgba(2,6,23,.28);
}
.landing-search-form{
  max-width:540px;
  margin-top:20px;
}
.landing-search-bar{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  min-height:52px;
  padding:5px;
  border:1px solid rgba(255,255,255,.2);
  border-radius:13px;
  background:#fff;
  box-shadow:0 16px 34px rgba(2,6,23,.18);
}
.landing-search-prefix{
  padding:0 7px 0 11px;
  color:#64748b;
  font-family:var(--display);
  font-size:14px;
  font-weight:800;
}
.landing-search-bar input{
  width:100%;
  min-width:0;
  height:42px;
  border:0;
  color:#052e16;
  font-family:var(--display);
  font-size:17px;
  font-weight:800;
}
.landing-search-bar input::placeholder{
  color:#94a3b8;
}
.landing-search-bar button{
  min-width:136px;
  min-height:42px;
  padding:0 18px;
  border:0;
  border-radius:10px;
  background:#14532d;
  color:#fff;
  font-family:var(--display);
  font-size:14px;
  font-weight:900;
  cursor:pointer;
  transition:background var(--t),transform var(--t),opacity var(--t);
}
.landing-search-bar button:hover{
  background:#0f3f22;
  transform:translateY(-1px);
}
.landing-search-bar button:disabled{
  cursor:wait;
  opacity:.68;
  transform:none;
}
.landing-search-results{
  display:none;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
  color:#dcfce7;
  font-size:13px;
  font-weight:800;
}
.landing-search-results.is-visible{
  display:flex;
}
.landing-search-results.is-error{
  color:#fee2e2;
}
.landing-result-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:32px;
  padding:6px 9px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  background:rgba(255,255,255,.1);
  color:#fff;
}
.landing-result-pill strong{
  padding:3px 7px;
  border-radius:999px;
  font-size:11px;
  font-weight:900;
}
.landing-result-pill.available strong{
  background:#dcfce7;
  color:#166534;
}
.landing-result-pill.taken strong{
  background:#fee2e2;
  color:#991b1b;
}
.landing-result-pill.unknown strong{
  background:#e0f2fe;
  color:#075985;
}
body.portal-guest .dashboard-landing-actions{
  justify-content:flex-start;
  gap:10px;
  margin-top:15px;
}
body.portal-guest .dashboard-landing-cta{
  min-height:44px;
  padding:10px 18px;
  border-radius:12px;
  font-size:14px;
  letter-spacing:0;
}
body.portal-guest .dashboard-landing-cta.primary{
  background:#fff;
  color:#0f3f22;
  box-shadow:0 16px 32px rgba(2,6,23,.18);
}
body.portal-guest .dashboard-landing-cta.secondary{
  border:1px solid rgba(255,255,255,.32);
  background:rgba(255,255,255,.09);
  color:#fff;
  box-shadow:none;
}
body.portal-guest .dashboard-landing-cta.secondary:hover{
  background:rgba(255,255,255,.16);
  color:#fff;
}
.landing-portal-preview{
  padding:18px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  background:rgba(255,255,255,.11);
  color:#fff;
  box-shadow:0 24px 54px rgba(2,6,23,.24),inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
}
.landing-preview-top,
.landing-preview-domain{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.landing-preview-top{
  margin-bottom:16px;
  color:rgba(255,255,255,.7);
  font-size:12px;
  font-weight:900;
}
.landing-preview-top strong,
.landing-preview-domain em{
  padding:5px 8px;
  border-radius:999px;
  background:#dcfce7;
  color:#166534;
  font-size:11px;
  font-style:normal;
  font-weight:900;
}
.landing-preview-domain{
  min-height:62px;
  padding:14px;
  border-radius:12px;
  background:#fff;
  color:#052e16;
  box-shadow:0 14px 28px rgba(2,6,23,.16);
}
.landing-preview-domain span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-family:var(--display);
  font-size:17px;
  font-weight:900;
}
.landing-preview-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
}
.landing-preview-grid div{
  min-height:78px;
  padding:12px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  background:rgba(255,255,255,.1);
}
.landing-preview-grid span,
.landing-preview-grid strong{
  display:block;
}
.landing-preview-grid span{
  margin-bottom:7px;
  color:rgba(255,255,255,.65);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
}
.landing-preview-grid strong{
  color:#fff;
  font-size:13px;
  line-height:1.25;
  overflow-wrap:anywhere;
}
.landing-preview-grid strong.landing-dns-stack{
  line-height:1.55;
}
body.portal-guest .dashboard-landing-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr));
  border-top:1px solid #dbe7f0;
  background:#fff;
}
body.portal-guest .dashboard-landing-feature{
  min-width:0;
  padding:19px 22px 18px;
  background:#fff;
  border-right:1px solid #e2e8f0;
}
body.portal-guest .dashboard-landing-feature:last-child{
  border-right:0;
}
body.portal-guest .dashboard-landing-feature:hover{
  background:#f8fbff;
}
body.portal-guest .dashboard-landing-feature-icon{
  width:36px;
  height:36px;
  margin-bottom:10px;
  border-radius:12px;
}
body.portal-guest .dashboard-landing-feature-title{
  margin-bottom:5px;
  color:#052e16;
  font-size:14px;
}
body.portal-guest .dashboard-landing-feature-copy{
  max-width:230px;
  color:#475569;
  font-size:13px;
  line-height:1.45;
}
body.portal-guest .dashboard-landing-footer{
  padding:16px 20px!important;
  border-top:1px solid #e2e8f0;
  background:#f8fafc!important;
}
.landing-proof-bar{
  display:grid;
  grid-template-columns:1fr;
  gap:13px;
  padding:15px 16px;
  border:1px solid #dbe7f0;
  border-radius:16px;
  background:
    radial-gradient(circle at 92% 16%,rgba(34,197,94,.1),transparent 32%),
    linear-gradient(135deg,#fff 0%,#f6fbf8 100%);
  box-shadow:0 12px 28px rgba(15,23,42,.05);
}
.landing-proof-copy{
  min-width:0;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  column-gap:16px;
  row-gap:9px;
  align-items:start;
}
.landing-proof-copy > strong{
  display:block;
  margin-bottom:4px;
  color:#052e16;
  font-family:var(--display);
  font-size:16px;
  font-weight:900;
}
.landing-proof-copy > span{
  display:block;
  max-width:560px;
  color:#475569;
  font-size:13px;
  line-height:1.35;
}
body.portal-guest .landing-order-points{
  grid-column:2;
  grid-row:1 / span 2;
  align-self:center;
  justify-content:flex-end;
  margin-top:0;
}
body.portal-guest .landing-order-points em{
  padding:6px 9px;
  border-radius:999px;
  background:#edf7f1;
  color:#166534;
  font-size:12px;
}
.landing-order-console{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-items:start;
}
.landing-order-console .landing-search-form{
  max-width:none;
  width:100%;
  margin-top:0;
}
.landing-domain-compose{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,330px);
  gap:10px;
  align-items:stretch;
}
.landing-order-console .landing-search-bar{
  grid-template-columns:auto minmax(0,1fr);
  min-height:54px;
  height:100%;
  border-color:#d9e7df;
  box-shadow:0 10px 26px rgba(15,23,42,.08);
}
.landing-domain-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.landing-domain-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  min-width:0;
  min-height:54px;
  padding:0 13px;
  border:0;
  border-radius:13px;
  font-family:var(--display);
  font-size:14px;
  font-weight:900;
  line-height:1.1;
  text-align:center;
  text-decoration:none;
  white-space:normal;
  cursor:pointer;
  -webkit-appearance:none;
  appearance:none;
  transition:background var(--t),color var(--t),transform var(--t),box-shadow var(--t),opacity var(--t);
}
.landing-domain-action span{
  color:inherit!important;
}
.landing-domain-action.check{
  border:1px solid #17643a;
  background:#17643a;
  color:#fff!important;
  box-shadow:0 12px 24px rgba(20,83,45,.18);
}
.landing-domain-action.order{
  border:1px solid #0b7a42;
  background:#0b7a42;
  color:#fff!important;
  box-shadow:0 12px 24px rgba(11,122,66,.18);
}
.landing-domain-action:hover{
  transform:translateY(-1px);
  text-decoration:none;
}
.landing-domain-action.check:hover,
.landing-domain-action.order:hover{
  background:#0d4f2d;
  border-color:#0d4f2d;
  color:#fff!important;
}
.landing-domain-action:disabled{
  background:#17643a;
  border-color:#17643a;
  color:#fff!important;
  cursor:progress;
  opacity:1;
  transform:none;
}
.landing-domain-action.is-pending,
.landing-domain-action.is-pending:hover{
  border-color:#d7e4db;
  background:#eef5f0;
  color:#5d7467!important;
  box-shadow:none;
  cursor:not-allowed;
  transform:none;
}
.landing-action-step{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 22px;
  width:22px;
  height:22px;
  border-radius:8px;
  background:rgba(255,255,255,.22);
  color:inherit;
  font-size:12px;
  font-weight:900;
}
.landing-domain-action.check .landing-action-step,
.landing-domain-action.order:not(.is-pending) .landing-action-step{
  background:rgba(255,255,255,.24);
  color:#fff!important;
}
.landing-domain-action.is-pending .landing-action-step{
  background:#fff;
  color:#71877a!important;
}
.landing-order-console .landing-search-results{
  color:#166534;
}
.landing-order-console .landing-search-results.is-error{
  color:#b91c1c;
}
.landing-order-console .landing-search-results.is-hint{
  color:#475569;
}
.landing-order-console .landing-result-pill{
  border-color:#dbe7f0;
  background:#fff;
  color:#0f172a;
  box-shadow:0 8px 18px rgba(15,23,42,.04);
}
.landing-order-console .landing-result-pill.can-order{
  cursor:pointer;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.landing-order-console .landing-result-pill.can-order:hover{
  border-color:#bbf7d0;
  box-shadow:0 10px 22px rgba(20,83,45,.09);
  transform:translateY(-1px);
}
body.portal-guest #footer{
  padding:13px 24px;
}
body.portal-guest #footer > .row{
  padding:0!important;
}

@media(max-width:900px){
  body.portal-guest .landing-card{
    min-height:0;
  }
  body.portal-guest .dashboard-landing-inner{
    grid-template-columns:1fr;
  }
  .landing-portal-preview{
    max-width:520px;
  }
  body.portal-guest .dashboard-landing-grid{
    grid-template-columns:1fr 1fr;
  }
  body.portal-guest .dashboard-landing-feature:nth-child(2){
    border-right:0;
  }
  body.portal-guest .dashboard-landing-feature:nth-child(-n+2){
    border-bottom:1px solid #e2e8f0;
  }
  .landing-proof-copy{
    grid-template-columns:1fr;
  }
  body.portal-guest .landing-order-points{
    grid-column:auto;
    grid-row:auto;
    justify-content:flex-start;
  }
  .landing-domain-compose{
    grid-template-columns:1fr;
  }
}

@media(max-width:560px){
  body.portal-guest > .container:not(.head_s_a):not(#footer){
    padding:0 14px;
  }
  body.portal-guest > .container:not(.head_s_a):not(#footer) > .row{
    padding-top:16px;
    padding-bottom:16px;
  }
  body.portal-guest .dashboard-landing-hero{
    padding:24px 18px;
  }
  body.portal-guest .dashboard-landing-title{
    font-size:27px;
  }
  .landing-search-bar{
    grid-template-columns:auto minmax(0,1fr);
  }
  .landing-search-bar button{
    grid-column:1 / -1;
    width:100%;
    margin-top:6px;
  }
  body.portal-guest .dashboard-landing-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .landing-login-panel{
    grid-template-columns:1fr;
  }
  .landing-login-panel .landing-login-cta{
    width:100%;
  }
  .landing-portal-preview{
    display:none;
  }
  body.portal-guest .dashboard-landing-grid{
    grid-template-columns:1fr;
  }
  body.portal-guest .dashboard-landing-feature,
  body.portal-guest .dashboard-landing-feature:nth-child(2),
  body.portal-guest .dashboard-landing-feature:nth-child(-n+2){
    border-right:0;
    border-bottom:1px solid #e2e8f0;
  }
  body.portal-guest .dashboard-landing-feature:last-child{
    border-bottom:0;
  }
  .landing-order-console{
    grid-template-columns:1fr;
  }
  .landing-domain-actions{
    grid-template-columns:1fr 1fr;
  }
  body.portal-guest .landing-order-points,
  .landing-search-results.is-visible{
    display:grid;
    grid-template-columns:1fr;
  }
  body.portal-guest .landing-path-btn.order{
    width:100%;
  }
}

@media(max-width:430px){
  .landing-domain-actions{
    grid-template-columns:1fr;
  }
}

/* frontend section-card pass: carry the edit-domain section language outward */
.client-record-section,
.profile-security-card,
.watchlist-card,
.epp-confirm-card,
.epp-destination-card,
.epp-sensitive-note,
.action-result,
.dashboard-home .dashboard-main-grid .box_c,
.audit-toolbar,
.audit-readonly-note,
.audit-row{
  --section-accent:#14532d;
  --section-accent-dark:#0f3f22;
  --section-surface:#f8fffb;
  --section-surface-2:#eefaf4;
  --section-border:#cfe8d6;
  --section-glow:rgba(20,83,45,.08);
  position:relative;
  isolation:isolate;
  overflow:hidden;
  border:1.5px solid var(--section-border)!important;
  border-radius:8px!important;
  background:
    linear-gradient(135deg,#fff 0%,var(--section-surface) 54%,var(--section-surface-2) 100%)!important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.6),0 14px 30px var(--section-glow)!important;
}
.client-record-section::before,
.profile-security-card::before,
.watchlist-card::before,
.epp-confirm-card::before,
.epp-destination-card::before,
.epp-sensitive-note::before,
.action-result::before,
.dashboard-home .dashboard-main-grid .box_c::before,
.audit-toolbar::before,
.audit-readonly-note::before,
.audit-row::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:6px;
  background:linear-gradient(180deg,var(--section-accent),var(--section-accent-dark));
  z-index:0;
}
.client-record-section::after,
.profile-security-card::after,
.watchlist-card::after,
.epp-confirm-card::after,
.epp-destination-card::after,
.epp-sensitive-note::after,
.action-result::after,
.dashboard-home .dashboard-main-grid .box_c::after,
.audit-toolbar::after,
.audit-readonly-note::after{
  content:'';
  position:absolute;
  right:14px;
  top:14px;
  width:92px;
  height:38px;
  background:repeating-linear-gradient(135deg,var(--section-border) 0 1px,transparent 1px 8px);
  opacity:.24;
  pointer-events:none;
  z-index:0;
}
.client-record-section > *,
.profile-security-card > *,
.watchlist-card > *,
.epp-confirm-card > *,
.epp-destination-card > *,
.epp-sensitive-note > *,
.action-result > *,
.dashboard-home .dashboard-main-grid .box_c > *,
.audit-toolbar > *,
.audit-readonly-note > *,
.audit-row > *{
  position:relative;
  z-index:1;
}

/* client.php: separate registry data into readable colored sections */
.client-record-sections{
  gap:14px;
  padding:18px;
  background:#f8fafc;
}
.client-record-section{
  border-bottom:1.5px solid var(--section-border)!important;
  padding:20px 22px 18px 28px;
}
.client-section-contact{
  --section-accent:#0f766e;
  --section-accent-dark:#115e59;
  --section-surface:#f0fdfa;
  --section-surface-2:#ccfbf1;
  --section-border:#99f6e4;
  --section-glow:rgba(15,118,110,.08);
}
.client-section-legal{
  --section-accent:#2563eb;
  --section-accent-dark:#1e3a8a;
  --section-surface:#eff6ff;
  --section-surface-2:#dbeafe;
  --section-border:#bfdbfe;
  --section-glow:rgba(37,99,235,.08);
}
.client-section-address{
  --section-accent:#d97706;
  --section-accent-dark:#92400e;
  --section-surface:#fffbeb;
  --section-surface-2:#fef3c7;
  --section-border:#fde68a;
  --section-glow:rgba(180,83,9,.08);
}
.client-record-field{
  border-radius:8px;
  background:rgba(255,255,255,.84);
  border-color:var(--section-border);
}

/* profile.php: password and 2FA now read as distinct panels */
.profile-security-console{
  background:linear-gradient(180deg,#f8fafc 0%,#f3f8f5 100%);
}
.profile-security-card{
  padding-left:6px;
}
.profile-security-card-head{
  background:transparent!important;
  border-bottom:1px solid var(--section-border)!important;
}
.profile-security-card-body{
  background:rgba(255,255,255,.66);
}
.password-card{
  --section-accent:#0f766e;
  --section-accent-dark:#115e59;
  --section-surface:#f0fdfa;
  --section-surface-2:#ccfbf1;
  --section-border:#99f6e4;
  --section-glow:rgba(15,118,110,.08);
}
.twofa-card.is-enabled{
  --section-accent:#2563eb;
  --section-accent-dark:#1e3a8a;
  --section-surface:#eff6ff;
  --section-surface-2:#dbeafe;
  --section-border:#bfdbfe;
  --section-glow:rgba(37,99,235,.08);
}
.twofa-card.is-disabled{
  --section-accent:#d97706;
  --section-accent-dark:#92400e;
  --section-surface:#fffbeb;
  --section-surface-2:#fef3c7;
  --section-border:#fde68a;
  --section-glow:rgba(180,83,9,.08);
}
.profile-rules-card{
  border-radius:8px;
  background:rgba(255,255,255,.78);
  border-color:var(--section-border);
}

/* domains.php: each domain row gets a status-colored lane */
.domains-console #dt2 tbody tr{
  --section-accent:#14532d;
  --section-accent-dark:#0f3f22;
  --section-border:#dbe7f0;
  --section-glow:rgba(15,23,42,.06);
  border-radius:8px!important;
  box-shadow:inset 6px 0 0 var(--section-accent),0 14px 30px var(--section-glow)!important;
}
.domains-console #dt2 tbody tr[data-status="active"]{
  --section-accent:#16a34a;
  --section-glow:rgba(22,163,74,.08);
}
.domains-console #dt2 tbody tr[data-status="expiring"]{
  --section-accent:#d97706;
  --section-glow:rgba(217,119,6,.1);
}
.domains-console #dt2 tbody tr[data-status="expired"]{
  --section-accent:#dc2626;
  --section-glow:rgba(220,38,38,.08);
}
.domains-console #dt2 tbody tr[data-status="deleted"]{
  --section-accent:#64748b;
  --section-glow:rgba(100,116,139,.08);
}
.domains-console .domain-command-bar,
.domains-console .domain-filter-banner{
  border-radius:8px;
  margin-left:20px;
  margin-right:20px;
  border:1.5px solid #dbe7f0;
}
.domains-console .domain-command-bar{
  margin-top:18px;
}

/* tools.php: watchlist becomes a proper task section */
.watchlist-card{
  --section-accent:#0f766e;
  --section-accent-dark:#115e59;
  --section-surface:#f0fdfa;
  --section-surface-2:#e6fff8;
  --section-border:#99f6e4;
  --section-glow:rgba(15,118,110,.08);
  padding-left:6px;
}
.watchlist-card-head{
  background:transparent;
  border-bottom:1px solid var(--section-border);
}
.watchlist-add-form,
.watchlist-table td{
  background:rgba(255,255,255,.78);
}

/* send-epp-code.php: confirmation flow uses warning/info/success lanes */
.epp-confirm-card,
.epp-sensitive-note{
  --section-accent:#d97706;
  --section-accent-dark:#92400e;
  --section-surface:#fffbeb;
  --section-surface-2:#fef3c7;
  --section-border:#fde68a;
  --section-glow:rgba(180,83,9,.08);
}
.epp-destination-card{
  --section-accent:#2563eb;
  --section-accent-dark:#1e3a8a;
  --section-surface:#eff6ff;
  --section-surface-2:#dbeafe;
  --section-border:#bfdbfe;
  --section-glow:rgba(37,99,235,.08);
}
.action-result{
  --section-accent:#16a34a;
  --section-accent-dark:#166534;
  --section-surface:#f0fdf4;
  --section-surface-2:#dcfce7;
  --section-border:#bbf7d0;
  --section-glow:rgba(22,163,74,.1);
}

/* logs.php: audit surfaces and rows now carry type-based color */
.audit-toolbar{
  --section-accent:#2563eb;
  --section-accent-dark:#1e3a8a;
  --section-surface:#eff6ff;
  --section-surface-2:#f8fbff;
  --section-border:#bfdbfe;
  --section-glow:rgba(37,99,235,.07);
  padding-left:24px;
}
.audit-readonly-note{
  --section-accent:#d97706;
  --section-accent-dark:#92400e;
  --section-surface:#fffbeb;
  --section-surface-2:#fef3c7;
  --section-border:#fde68a;
  --section-glow:rgba(180,83,9,.08);
  padding-left:20px;
}
.audit-row{
  --section-accent:#94a3b8;
  --section-accent-dark:#475569;
  --section-surface:#fff;
  --section-surface-2:#f8fafc;
  --section-border:#e2e8f0;
  --section-glow:rgba(15,23,42,.05);
  padding-left:18px;
}
.audit-row[data-type="security"]{
  --section-accent:#dc2626;
  --section-accent-dark:#991b1b;
  --section-surface:#fff7f7;
  --section-surface-2:#fee2e2;
  --section-border:#fecaca;
}
.audit-row[data-type="epp"]{
  --section-accent:#7c3aed;
  --section-accent-dark:#4c1d95;
  --section-surface:#f8f5ff;
  --section-surface-2:#ede9fe;
  --section-border:#ddd6fe;
}
.audit-row[data-type="domain"]{
  --section-accent:#0f766e;
  --section-accent-dark:#115e59;
  --section-surface:#f0fdfa;
  --section-surface-2:#ccfbf1;
  --section-border:#99f6e4;
}
.audit-row[data-type="contact"]{
  --section-accent:#2563eb;
  --section-accent-dark:#1e3a8a;
  --section-surface:#eff6ff;
  --section-surface-2:#dbeafe;
  --section-border:#bfdbfe;
}
.audit-row[data-type="login"]{
  --section-accent:#16a34a;
  --section-accent-dark:#166534;
  --section-surface:#f0fdf4;
  --section-surface-2:#dcfce7;
  --section-border:#bbf7d0;
}

/* dashboard: secondary content follows the same separated-panel rhythm */
.dashboard-home .dashboard-main-grid .box_c{
  --section-accent:#d97706;
  --section-accent-dark:#92400e;
  --section-surface:#fffbeb;
  --section-surface-2:#fff7d6;
  --section-border:#fde68a;
  --section-glow:rgba(180,83,9,.08);
}
.dashboard-home .dashboard-actions-panel{
  --section-accent:#14532d;
  --section-accent-dark:#0f3f22;
  --section-surface:#f8fffb;
  --section-surface-2:#eefaf4;
  --section-border:#cfe8d6;
  --section-glow:rgba(20,83,45,.08);
}
.dashboard-home .dashboard-attention-panel{
  --section-accent:#d97706;
  --section-accent-dark:#92400e;
  --section-surface:#fffbeb;
  --section-surface-2:#fff7d6;
  --section-border:#fde68a;
  --section-glow:rgba(180,83,9,.08);
}
.dashboard-home .dashboard-pending-docs-panel{
  --section-accent:#b91c1c;
  --section-accent-dark:#7f1d1d;
  --section-surface:#fef2f2;
  --section-surface-2:#fee2e2;
  --section-border:#fecaca;
  --section-glow:rgba(185,28,28,.10);
}
.dashboard-pending-kicker{
  display:inline-block;
  margin-bottom:6px;
  padding:3px 9px;
  border-radius:999px;
  background:rgba(185,28,28,.12);
  color:#7f1d1d;
  font:700 11px Arial,sans-serif;
  text-transform:uppercase;
  letter-spacing:.07em;
}

/* Authenticated hero normalization: keep page-to-page movement predictable. */
.domain-hero,
.dashboard-home .dashboard-hero,
.tools-hero{
  min-height:236px;
  box-sizing:border-box;
  overflow:hidden;
  background:
    radial-gradient(circle at 82% 16%,rgba(34,197,94,.18),transparent 26%),
    radial-gradient(circle at 12% 88%,rgba(14,165,233,.12),transparent 28%),
    linear-gradient(135deg,#0f4b16 0%,#14532d 48%,#12395a 100%)!important;
}
.domain-hero,
.dashboard-home .dashboard-hero{
  grid-template-columns:minmax(0,1.12fr) minmax(320px,.88fr);
  align-items:stretch;
}
.domain-hero-main,
.dashboard-home .dashboard-hero-main,
.tools-hero{
  min-height:236px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:30px 32px!important;
  box-sizing:border-box;
}
.domain-hero-side,
.dashboard-home .dashboard-hero-side{
  min-height:236px;
  padding:26px 30px!important;
  align-content:center;
  box-sizing:border-box;
}
.domain-hero-title,
.dashboard-home .dashboard-hero-title,
.tools-hero-title{
  max-width:660px;
  font-size:32px!important;
  line-height:1.15!important;
  letter-spacing:0!important;
}
.domain-hero-copy,
.dashboard-home .dashboard-hero-copy,
.tools-hero-copy{
  max-width:640px;
  min-height:48px;
  font-size:15px!important;
  line-height:1.55!important;
}
.domain-hero-kicker,
.dashboard-home .dashboard-kicker,
.tools-hero-kicker{
  min-height:26px;
  margin-bottom:16px!important;
  letter-spacing:.08em!important;
}
.domain-stat{
  border-radius:8px;
}
.dashboard-home .dashboard-side-card{
  border-radius:8px;
}
@media(max-width:767px){
  .domain-hero,
  .dashboard-home .dashboard-hero{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .tools-hero{
    min-height:188px;
  }
  .domain-hero-main,
  .dashboard-home .dashboard-hero-main,
  .tools-hero{
    min-height:188px;
    padding:22px 18px!important;
  }
  .domain-hero-side,
  .dashboard-home .dashboard-hero-side{
    min-height:auto;
    padding:20px 18px!important;
    border-left:none!important;
    border-top:1px solid rgba(255,255,255,.12);
  }
  .domain-hero-title,
  .dashboard-home .dashboard-hero-title,
  .tools-hero-title{
    font-size:26px!important;
  }
  .domain-hero-copy,
  .dashboard-home .dashboard-hero-copy,
  .tools-hero-copy{
    min-height:auto;
  }
}
@media(max-width:700px){
  .client-record-sections{
    padding:14px;
  }
  .client-record-section,
  .profile-security-card,
  .watchlist-card,
  .audit-row{
    border-radius:8px!important;
  }
  .domains-console .domain-command-bar,
  .domains-console .domain-filter-banner{
    margin-left:16px;
    margin-right:16px;
  }
}

/* Mobile overflow guard: keep the portal usable without horizontal scrolling. */
@media(max-width:767px){
  html,body{
    max-width:100%;
    overflow-x:hidden;
  }
  .container,
  .row,
  .columns,
  .column,
  .box_c,
  .box_c_heading,
  .box_c_content,
  form,
  fieldset,
  .client-record-console,
  .client-record-sections,
  .client-record-section,
  .profile-security-console,
  .profile-security-card,
  .domain-editor,
  .domain-renewal-panel,
  .domain-section,
  .domain-timeline-panel,
  .domain-task-card,
  .domains-console,
  .tools-console,
  .audit-row{
    min-width:0!important;
    max-width:100%!important;
    box-sizing:border-box!important;
  }
  .gh_button,
  .button,
  input[type=submit],
  input[type=button],
  button:not(.nav-toggle){
    white-space:normal!important;
    overflow-wrap:anywhere;
    text-align:center;
  }
  .domain-form-actions,
  .profile-inline-form,
  .watchlist-add-form,
  .epp-confirm-actions{
    align-items:stretch!important;
  }
  .domain-form-actions>*,
  .profile-inline-form>*,
  .watchlist-add-form>*,
  .epp-confirm-actions>*{
    max-width:100%!important;
  }
}

@media(max-width:479px){
  .domain-form-actions>*,
  .profile-inline-form>*,
  .watchlist-add-form>*,
  .epp-confirm-actions>*{
    width:100%!important;
    justify-content:center;
  }
}

/* logs.php: audit dashboard refresh */
.audit-metric-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  padding:18px 20px;
  border-bottom:1px solid #dbe7f0;
  background:#f8fafc;
}
.audit-metric-card{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
  padding:14px;
  border:1px solid #dbe7f0;
  border-radius:8px;
  background:#fff;
  text-decoration:none;
  box-shadow:0 10px 24px rgba(15,23,42,.05);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.audit-metric-card:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(15,23,42,.08);
  text-decoration:none;
}
.audit-metric-mark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 42px;
  width:42px;
  height:42px;
  border-radius:8px;
  color:#fff;
  font-family:var(--display);
  font-size:12px;
  font-weight:900;
}
.audit-metric-copy{
  min-width:0;
  display:grid;
  gap:2px;
}
.audit-metric-copy strong{
  color:#0f172a;
  font-family:var(--display);
  font-size:24px;
  font-weight:900;
  line-height:1;
}
.audit-metric-copy em{
  color:#64748b;
  font-size:12px;
  font-style:normal;
  font-weight:800;
  line-height:1.25;
}
.audit-metric-card.security .audit-metric-mark{background:#dc2626}
.audit-metric-card.domain .audit-metric-mark{background:#0f766e}
.audit-metric-card.epp .audit-metric-mark{background:#7c3aed}
.audit-metric-card.contact .audit-metric-mark{background:#2563eb}
.audit-metric-card.security:hover{border-color:#fecaca}
.audit-metric-card.domain:hover{border-color:#99f6e4}
.audit-metric-card.epp:hover{border-color:#ddd6fe}
.audit-metric-card.contact:hover{border-color:#bfdbfe}

.audit-shell .audit-toolbar{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  align-items:stretch;
  padding:18px 20px;
}
.audit-toolbar-controls{
  display:grid;
  grid-template-columns:minmax(260px,1fr) minmax(220px,300px);
  gap:14px;
  align-items:end;
}
.audit-filter-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.audit-filter-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:36px;
  padding:7px 10px;
  border:1px solid #dbe7f0;
  border-radius:8px;
  background:#fff;
  color:#334155;
  font-family:var(--display);
  font-size:13px;
  font-weight:850;
  text-decoration:none;
  transition:background var(--t),border-color var(--t),color var(--t),box-shadow var(--t);
}
.audit-filter-chip strong{
  min-width:24px;
  padding:2px 7px;
  border-radius:999px;
  background:#f1f5f9;
  color:#64748b;
  font-size:12px;
  text-align:center;
}
.audit-filter-chip:hover{
  border-color:#b6cadc;
  color:#0f172a;
  text-decoration:none;
  box-shadow:0 8px 18px rgba(15,23,42,.05);
}
.audit-filter-chip.active{
  border-color:#14532d;
  background:#14532d;
  color:#fff;
}
.audit-filter-chip.active strong{
  background:rgba(255,255,255,.18);
  color:#fff;
}
.audit-filter-chip.security.active{border-color:#dc2626;background:#dc2626}
.audit-filter-chip.epp.active{border-color:#7c3aed;background:#7c3aed}
.audit-filter-chip.domain.active{border-color:#0f766e;background:#0f766e}
.audit-filter-chip.contact.active{border-color:#2563eb;background:#2563eb}
.audit-filter-chip.login.active{border-color:#16a34a;background:#16a34a}
.audit-filter-chip.other.active{border-color:#64748b;background:#64748b}

.audit-shell .log-row{
  grid-template-columns:46px minmax(0,1fr) minmax(128px,auto);
  align-items:center;
  border-radius:8px;
}
.audit-shell .log-icon{
  width:42px;
  height:42px;
  border-radius:8px;
  font-size:11px;
  letter-spacing:0;
}
.audit-shell .log-message{
  font-size:15px;
  line-height:1.45;
}
.audit-shell .log-meta{
  border-radius:8px;
}
.timeline-empty{
  margin:22px;
  border:1px dashed #cbd5e1;
  border-radius:8px;
  background:#fff;
}
.timeline-empty-emoji{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 12px;
  border-radius:8px;
  background:#f1f5f9;
  color:#475569;
  font-family:var(--display);
  font-size:12px;
  font-weight:900;
}

@media(max-width:900px){
  .audit-metric-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:767px){
  .audit-metric-grid{
    padding:14px 16px;
  }
  .audit-toolbar-controls{
    grid-template-columns:1fr;
  }
  .audit-filter-chips{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .audit-filter-chip{
    justify-content:space-between;
  }
  .audit-shell .log-row{
    grid-template-columns:42px minmax(0,1fr);
    align-items:start;
  }
}
@media(max-width:520px){
  .audit-metric-grid,
  .audit-filter-chips{
    grid-template-columns:1fr;
  }
}

